利用指针运算打乱散转命令运行地址以增加反汇编难度(9166字)hotpower[17次]2004-9-5 12:26:01 利用指针运算打乱散转命令运行地址以增加反汇编难度 HotPower 发表于 2004-8-24 00:08 侃单片机 ←返回版面 举报该贴
/*------------------------------------------------------------------ 利用函数指针数组运行PS2键盘散转命令 -------------------------------------------------------------------*/ void PS2CommandExec(unsigned char key) { unsigned int i; code void *funcpushbuffers[] = {//命令散转表(汇编中的16个DW) /*------------------------------------------------------------------ 15个压键、放键及长压键事件处理函数指针地址 -------------------------------------------------------------------*/ (void *)ClrWdt + 0x0000, /*--------------------------------------------- 10个功能键压键事件处理(独立管理) ----------------------------------------------*/ (void *)PS2F1KeyPush + 0x5b7d, //功能键F1压键事件处理 (void *)PS2F2KeyPush + 0xa6ea, //功能键F2压键事件处理 (void *)PS2F3KeyPush + 0xf157, //功能键F3压键事件处理 (void *)PS2F4KeyPush + 0x4cc4, //功能键F4压键事件处理 (void *)PS2F5KeyPush + 0x9731, //功能键F5压键事件处理 (void *)PS2F6KeyPush + 0xe2ae, //功能键F6压键事件处理 (void *)PS2EnterKeyPush + 0x3d1b, //功能键Enter压键事件处理 (void *)PS2EscKeyPush + 0x8888, //功能键Esc压键事件处理 (void *)PS2BkspKeyPush + 0xd3f5, //功能键Bksp压键事件处理 (void *)PS2KpKeyPush + 0x2e62, //功能键Kp压键事件处理 /*--------------------------------------------- 2个放键事件处理(集中管理) ----------------------------------------------*/ (void *)PS2NumberKeyPop + 0x79df, //数字键放键事件处理 (void *)PS2FuncKeyPop + 0xc44c, //功能键放键事件处理 /*--------------------------------------------- 2个长压键事件处理(集中管理) ----------------------------------------------*/ (void *)PS2NumberKeyPushL + 0x1fb9, //数字键长压键事件处理 (void *)PS2FuncKeyPushL + 0x6a26, //功能键长压键事件处理 /*--------------------------------------------- 1个数字键压键事件处理(集中管理) ----------------------------------------------*/ (void *)PS2NumberKeyPush + 0xb593 //数字键0~9压键事件处理 }; /*--------------------------------------------*/ i = key; key &= 0x3f;//去掉键释放及长压键标志,取真键码 key --; if (key < 20){//只有20个键 if (key < 10){//数字键0~9 if (i <= 10) key = 15;//(散转号0)压数字键0~9 else{ if (i & 0x80) key = 11;//(散转号11)放数字键0~9 else key = 13;//(散转号13)长压数字键0~9 } } else{//压功能键F1~F6,Enter..KP if ((i & 0xc0) == 0) key -= 9;//(散转号1~10)压功能键F1~F6,Enter..KP else{ if (i & 0x80) key = 12;//(散转号12)放功能键 else key = 14;//(散转号14)长压功能键 } } ClrWdt();//喂狗(鬼知道键盘程序要运行多久,就替它先喂一次吧) i = ((key * 53 & 0xf) * 0x1000)+ ((key * 43 & 0xf) * 0x100) + ((key * 23 & 0xf) * 0x10) + (key * 13 & 0xf); _icall_((void *)funcpushbuffers[key] - i);//取键盘散转表并执行键盘命令 } } 相关链接:http://www.daxia.com/bibis/lookgood.asp?lookid=2638 |