X86 AT&T常用寄存器及其操作指令

X86 AT&T常用寄存器及其操作指令

常用寄存器

  • esp寄存器:当我们需要访问堆栈帧中的变量时,可以使用esp寄存器来获取堆栈帧的基址,以便能够正确地访问堆栈帧中的变量。
  • ebp寄存器:当我们需要调用一个函数时,可以使用ebp寄存器来获取函数的参数,以便能够正确地传递参数给函数。
  • eax寄存器:当我们需要调用一个函数时,可以将函数的参数存储在eax寄存器中,以便函数能够正确地接收参数。
  • ebx寄存器:当我们需要访问一个数组时,可以将数组的基址存储在ebx寄存器中,以便能够正确地访问数组。
  • ecx寄存器:当我们需要实现一个循环时,可以将循环的计数器存储在ecx寄存器中,以便能够正确地实现循环。
  • edx寄存器:当我们需要实现乘除法运算时,可以将乘除法运算的结果存储在edx寄存器中,以便能够正确地实现乘除法运算。
  • esi寄存器:当我们需要实现字符串复制时,可以将源地址存储在esi寄存器中,以便能够正确地实现字符串复制。
  • edi寄存器:当我们需要实现字符串复制时,可以将目的地址存储在edi寄存器中,以便能够正确地实现字符串复制。
    • 下面是一个使用EDI和ESI寄存器的AT&T汇编代码示例:
      movl %esi, %edi ; 将ESI的值复制到EDI
      movl $0x10, %ecx ; 将0x10存储到ECX寄存器
      rep movsb ; 从ESI指向的源地址复制ECX个字节到EDI指向的目标地址
    • CLD是一条8086汇编指令,它的作用是清除DF(Direction Flag)标志,以便让字符串操作指令(如MOVSB)从左到右执行。
  • eip寄存器:当我们需要实现跳转到另一个函数时,可以将下一条指令的地址存储在eip寄存器中,以便能够正确地实现跳转。

操作指令

操作这些寄存器的指令有:mov、add、sub、inc、dec、cmp、xchg、push、pop、lea、jmp、call等。

  • mov指令:用于将源操作数的值复制到目标操作数中,例如:movl %eax, %ebx,表示将eax寄存器中的值复制到ebx寄存器中。

    • 例子1:movl $0x1, %eax,这条指令将值0x1存储到寄存器eax中。
      例子2:leal 0x1(%ebx), %eax,这条指令将ebx + 0x1的地址存储到寄存器eax中。
      在这两个例子中,movl指令将值0x1存储到eax中,而leal指令将ebx + 0x1的地址存储到eax中。
  • add指令:用于将源操作数的值与目标操作数的值相加,例如:addl %eax, %ebx,表示将eax寄存器中的值与ebx寄存器中的值相加。

  • sub指令:用于将源操作数的值减去目标操作数的值,例如:subl %eax, %ebx,表示将eax寄存器中的值减去ebx寄存器中的值。

  • inc指令:用于将操作数的值加1,例如:incl %eax,表示将eax寄存器中的值加1。

  • dec指令:用于将操作数的值减1,例如:decl %eax,表示将eax寄存器中的值减1。

  • cmp指令:用于比较源操作数的值与目标操作数的值,例如:cmpl %eax, %ebx,表示比较eax寄存器中的值与ebx寄存器中的值。

    • cmpl %ebx , %eax; jle xx ; == if (%eax ≤%ebx) then jump to xx
  • xchg指令:用于交换源操作数的值与目标操作数的值,例如:xchgl %eax, %ebx,表示交换eax寄存器中的值与ebx寄存器中的值。

  • push指令:用于将操作数的值压入堆栈,例如:pushl %eax,表示将eax寄存器中的值压入堆栈。

  • pop指令:用于将堆栈中的值弹出到操作数中,例如:popl %eax,表示将堆栈中的值弹出到eax寄存器中。

  • lea指令:用于将操作数的值赋值给另一个操作数,例如:leal (%eax, %ebx), %ecx指令的作用是将eax + ebx的地址存储到ecx中。

  • jmp指令:用于跳转到指定的地址,例如:jmpl 0x12345,表示跳转到地址0x12345处。

    • JA 大于则跳转
    • JNBE 不小于或等于则跳转
    • JAE 大于等于跳转
    • JNB 不小于跳转
    • JB 小于跳转
    • JNAE 不大于等于跳转
    • JBE 小于等于跳转
    • JNA 不大于跳转
  • call指令:用于调用指定的函数,例如:calll 0x12345,表示调用地址0x12345处的函数。

  • 加减乘除操作可以使用add、sub、mul、div指令来实现

    • 例如:addl %eax, %ebx,表示将eax寄存器中的值与ebx寄存器中的值相加;
    • subl %eax, %ebx,表示将eax寄存器中的值减去ebx寄存器中的值;
    • mull %eax, %ebx,表示将eax寄存器中的值与ebx寄存器中的值相乘;
    • divl %eax, %ebx,表示将eax寄存器中的值除以ebx寄存器中的值。
    • 例如:imull $2, %eax,表示将eax寄存器中的值乘以2。
    • 可以使用shl指令来实现寄存器的值乘以2的幂次方,例如:shll $2, %eax,表示将eax寄存器中的值乘以4(2的2次方)
    • movl (%ebx,%eax,4), %ebx指令的作用是将ebx寄存器中的值加上eax寄存器中的值乘以4后的结果,作为ebx寄存器的新值。

示例

pushl %ebp://将ebp的值压入堆栈
movl %esp, %ebp://将esp的值赋给ebp
subl $24, %esp://从esp中减去24,以便为变量分配内存
andl $-16, %esp://将esp的值与-16进行按位与运算,以确保内存对齐
movl $0, %eax://将0存入eax
subl %eax, %esp://从esp中减去eax的值,以便为变量分配内存
movl $0, -20(%ebp)//将0存入ebp-20处的内存
movl $0, -16(%ebp)//将0存入ebp-16处的内存
movl $1, -12(%ebp)//将1存入ebp-12处的内存
movl $2, -12(%ebp)//将2存入ebp-12处的内存
movl $3, -8(%ebp)//将3存入ebp-8处的内存
movl $0, %eax://将0存入eax
leave://恢复ebp的值
ret://返回
  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

之墨_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值