汇编语言32位模式下传递64位参数
32 位模式中,通过堆栈向子程序传递 64 位参数时,先将参数的高位双字入栈,再将其低位双字入栈。这样就使得整数在堆栈中是按照小端顺序(低字节在低地址)存放的,因而子程序容易检索到这些数值,如同下面的 WriteHex64 过程操作一样。该过程用十六进制显示 64 位整数:
WriteHex64 PROC push ebp mov ebp, esp mov eax, [ebp+12] ;高位双字 call WriteHex mov eax, [ebp+8] ;低位双字 call WriteHex pop ebp ret 8 WriteHex64 ENDP
WriteHex64 的调用示例如下,它先把 longVal 的高半部分入栈,再把 longVal 的低半部分入栈:
.data longVal QWORD 1234567800ABCDEFh .code push DWORD PTR longVal + 4 ;高位双字 push DWORD PTR longVal ;低位双字 call WriteHex64
下图显示的是在 EBP 入栈,并把 ESP 复制给 EBP 之后,WriteHex64 的堆栈帧示意图。
发表评论