void MACRO_RETI(void)
{
asm_RETI() //里面就是一句匯編的RETI,,它會搶先與函數(shù)自己的RET執(zhí)行
}; //這個函數(shù)自己的RET永遠不執(zhí)行到,因為跳走了
void __HotASM_START__ (void) //啟動時運行的代碼
{
MACRO_CLR_EA; //關(guān)中斷
MACRO_Check_Crack; //反破解陷阱
MACRO_RETI(); //釋放中斷優(yōu)先級
MACRO_RETI(); //再釋放一次
MACRO_LJMP_ANY(main); //用壓棧和RET做的任意位置長跳轉(zhuǎn),,地址是main主程序
}; //這里其實會有個RET
菜農(nóng)來澄清匯編數(shù)組和匯編及嵌入?yún)R編最大的不同:
匯編數(shù)組內(nèi)實際存放的是數(shù)據(jù)而非代碼,,但用函數(shù)指針強行跳入后,,數(shù)據(jù)變“升華”
為代碼。
它本來就是為動態(tài)鏈接而設(shè)計,故編譯期間是找不到靜態(tài)地址的,,至少俺現(xiàn)在無
好辦法,。
即使能找到靜態(tài)地址,如匯編的:
lcall xxxx; ajmp xxx
都屬于此類,。
匯編數(shù)組是吳旭光教授與菜農(nóng)為以后能在任何MCS/ARM/DSP上運行OS
所參照PC的動態(tài)鏈接庫DLL/LIB所設(shè)計的,。
以前雖在DSP上應(yīng)用,但很局限,。
這次在51上大面積推廣,,故菜農(nóng)熬夜趕制了HotASM,HotCOM.HotMACRO等,
這樣可以用匯編數(shù)組(宏)通過COM接口直接相互訪問,,而且可以和C函數(shù)通訊,。
最近版本已全面支持C函數(shù)調(diào)用匯編數(shù)組宏,且宏在某些語句要比C精煉的多,。
并且很容易加入“反逆向代碼”且不影響正常程序,。
所以,匯編數(shù)組的編寫應(yīng)該基于動態(tài)鏈接的思想,,雖然這樣代碼效率會影響些
但不會影響主流,。
菜農(nóng)是實用主義,不愛說教,,只看結(jié)果,,不管過程。
所以不知XWJ的MACRO_RETI是否能運行,?,??
課畢