寄存器简单理解
在64位架构上,有些特殊寄存器:
RAX:返回值
RBX:被调用者保存
RCX:第四个参数
RDX:第三个参数
RSI:第四个参数
RDI:第三个参数
RBP:存放栈底指针
RSP:存放栈顶指针
R8:第5个参数
R9:第6个参数
R10~R15:被调用者保存
R8~R15属于普通寄存器,支持拆分,但是拆分的寄存器在命名规则上与特殊功能寄存器有所不同。32位拆分寄存器以D作为后缀(DWORD),16位寄存器以W作为后缀(WORD),8位则以B作为后缀(BYTE)。
常见汇编指令
1.NOP :交换指令,操作数为90,什么也不干
2.PUSH x:将x压入栈,esp先减再压数据
3.POP x: 将栈顶数据弹出到x中,esp递增
4.CALL x:将call指令下一条指令压入栈中,改变eip的值为x
5.RET: 将栈顶数据弹出到eip 若为RET X 表示esp再增加x字节
6.MOV 目的, 源:将源的值传给目的
7.LEA x1,x2:将x2的地址载入到x1
8.ADD x1,x2:x1=x1+x2