C语言中将绝对地址转换为函数指针以及跳转到内存指定位置处执行的技巧
生活随笔
收集整理的這篇文章主要介紹了
C语言中将绝对地址转换为函数指针以及跳转到内存指定位置处执行的技巧
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
要對絕對地址0x100000賦值,我們可以用
?? ? ?(unsigned int ?* ) 0x100000 = 1234;
?? ? ?那么要是想讓程序跳轉到絕對地址是0x100000去執行,應該怎么做?
?? ? *((void (*)( ))0x100000 ) ( );
?? ?首先要將0x100000強制轉換成函數指針,即:
?? ? (void (*)())0x100000
?? ? 然后再調用它:
?? *((void (*)())0x100000)();
?? 用typedef可以看得更直觀些:
?? ?typedef void(*)() voidFuncPtr;
?? *((voidFuncPtr)0x100000)(); ? 又如 如果用 C 語言,可以像下列示例代碼這樣來調用內核: void (*theKernel)(int zero, int arch, u32 params_addr)
= (void (*)(int, int, u32))KERNEL_RAM_BASE;?
……?
theKernel(0, ARCH_NUMBER, (u32) kernel_params_start);?
KERNEL_RAM_BASE 是內核在系統內存中的第一條指令的地址。
?? ? ?(unsigned int ?* ) 0x100000 = 1234;
?? ? ?那么要是想讓程序跳轉到絕對地址是0x100000去執行,應該怎么做?
?? ? *((void (*)( ))0x100000 ) ( );
?? ?首先要將0x100000強制轉換成函數指針,即:
?? ? (void (*)())0x100000
?? ? 然后再調用它:
?? *((void (*)())0x100000)();
?? 用typedef可以看得更直觀些:
?? ?typedef void(*)() voidFuncPtr;
?? *((voidFuncPtr)0x100000)(); ? 又如 如果用 C 語言,可以像下列示例代碼這樣來調用內核: void (*theKernel)(int zero, int arch, u32 params_addr)
= (void (*)(int, int, u32))KERNEL_RAM_BASE;?
……?
theKernel(0, ARCH_NUMBER, (u32) kernel_params_start);?
KERNEL_RAM_BASE 是內核在系統內存中的第一條指令的地址。
總結
以上是生活随笔為你收集整理的C语言中将绝对地址转换为函数指针以及跳转到内存指定位置处执行的技巧的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何访问固定的内存位置?
- 下一篇: C语言条件编译及编译预处理阶段