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 是內核在系統內存中的第一條指令的地址。
二、方法二
C語言使用函數指針跳轉到程序固定地址(0x8000)執行程序的方法函數

使用函數指針,把一個純數據強制轉換爲函數指針類型。指針

int main(void)內存

{
void (* my_function)(void);
//int *my_address = 0x8000;
my_function =(void (*)())(0x8000);
my_function();
}io

其實更簡單,不適用中間變量,直接一步到位:function

(*(void(*)())0x8000)();
--------------------- 
 變量

相關文章
相關標籤/搜索