标签:恢复 tps xiaomi 规则 int 汇编 保护 size 必须
在写汇编函数时,总感觉在哪些寄存器该保护哪些不需要保护的问题上比较模糊,要是保护所有使用到的寄存器感觉比较死板也不符合规则,所以就去网上搜了搜。找到了一些规则,我觉得这是一个规则问题,大家都遵守的话就可以相互复用函数了,当然这个规则也是有一定道理的。
1、你自己的函数在操作改变edi esi ebx ebp esp这几个寄存器的值时,你必须先保存这几个寄存器原先的值,并在函数返回之前恢复上述这几个寄存器原先的值。
2、你的函数在调用外部的函数时,edi esi ebx ebp esp这几个寄存器不会被函数修改(因为在函数中会保护这些寄存器),所以在调用外部函数时你的函数不用进行保存,但eax ecx edx这三个寄存器的值你的函数在调用外部函数前必须先保存(因为函数中不会保护这三个寄存器)。
还有就是关于栈恢复的问题,就是在调用函数之前的参数入栈和恢复栈的问题,可以采用C中的规则:
后面的参数先入栈,由调用者恢复栈(恢复时可以简单地使用add esp,num,其中num就是你入栈时的参数字节数)
---------------------
作者:xiaominthere
来源:CSDN
原文:https://blog.csdn.net/xiaominthere/article/details/17486129
版权声明:本文为博主原创文章,转载请附上博文链接!
标签:恢复 tps xiaomi 规则 int 汇编 保护 size 必须
原文地址:https://www.cnblogs.com/RexShao/p/10126786.html