Assembly instructions 汇编指令解析 A&AT


                                                                  Assembly instructions

汇编初步学习

汇编0基础的戳上面,刷一遍,包治百病






%eax寄存器的值与C语言的return的值相对应

(%esp)地址处储存的是函数的返回地址 return address



%esp 栈顶寄存器 保存栈顶指针。

%ebp = boundary between parameters and local variable

函数执行时不要改变这个寄存器的值!


pushl 指令究竟都干了什么:

            pushl x

等价于

            subl $4, %esp;

            movl x, (%esp) 


            有个常遇到的汇编代码 pushl %ebx 有点意思,

            这里就等价于

            subl $4 %esp

            movl %ebx (%esp)

  这里就把%ebx 寄存器的值储存在%esp 指向的内存地址了



同样popl命令与之相反.

             popl x

             movl %(esp) x

             add $4 %esp

这里就相当于恢复了原来x的值(x是寄存器)

calll  0x4005e8 <map>

就相当于

push %eip

jump 0x4005e8



ret 就相当于

popl %eip

leavel 相当于

movl %ebp, %esp; //恢复原来的栈顶

popl %ebp


如果编译器意识到没有变更%ebp的值,那么就会用调用leave,而是直接popl

例如仅有一个main函数的时候




leal 指令

我今天才知道 lea 是load effective address的缩写。。。

仅仅是简单的算术运算,不是解引用

    leal    0x400580,%rcx
把0x400580 加到%rcx里面去


 













评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值