第三章、汇编2

算术逻辑操作

加载有效地址

leaq 这个指令是烦人的,leaq (address), %rax, 首先(address)表示获取某个地址的值,而leaq(load effective address)又是去取得一个值的地址(&value),那么取得的结果就是address, 所以本质就是把address放到寄存器中。这个好处是可以利用一些简单的加法和乘法,减少指令个数。可以做一下书里的练习题。

一元和二元操作

  • inc
  • dec
  • neg
  • not

移位操作

特殊算术操作

控制

条件码

访问条件码

跳转指令

这里有个疑惑记录一下,140页书里有一行代码:7f f8 // jg 5

跳转指令相对位置编码很好理解,但是书里把0xf8翻译成-8我就很不理解,

问:为啥反汇编的话这么确定就把这个二进制当作补码处理来翻译?

查阅资料有人说汇编后的二进制数都是补码,这个姑且先这么看,权威资料没查到。

问:如果0xf8被翻译成-8,那么248这个数值二进制咋表示?

chat-gpt解释如下:其实jmp分为相对短跳转(short jump)和相对长跳转(near jump),二者的汇编虽然都是用jmp这三个字母,但是汇编器会根据输入立即数的大小翻译成不同的二进制, 指令分别被翻译EB(短跳转) 和 E9(长跳转), 二者立即数范围分别是1字节(-128~+127)和4字节 (-2,147,483,648 ~ +2,147,483,647)。举个例子:

  1. jmp $4096 最后会被汇编器翻译成:
    E9 00 00 10 00(小端机器)
  2. jmp $-8 最后会被汇编器翻译成:
    EB f8
  3. jmp $248 最后会被汇编器翻译成:
    E9 f8 00 00 00 (小端机器)

跳转指令的编码

用条件控制来实现条件分支

用条件传送来实现条件分支

switch语句

相关推荐
myloveasuka16 小时前
寻址方式笔记
汇编·笔记·计算机组成原理
请输入蚊子18 小时前
《操作系统真象还原》 第六章 完善内核
linux·汇编·操作系统·bochs·操作系统真像还原
myloveasuka19 小时前
指令格式举例
汇编·笔记·计算机组成原理
我在人间贩卖青春1 天前
汇编之分支跳转指令
汇编·arm·分支跳转
我在人间贩卖青春2 天前
汇编之加载存储指令
汇编·arm·寄存器加载存储
我在人间贩卖青春2 天前
汇编之状态寄存器访问指令
汇编·arm·状态寄存器
我在人间贩卖青春2 天前
汇编之软中断指令和协处理指令
汇编·arm·软中断·协处理
我在人间贩卖青春2 天前
汇编之数据处理指令
汇编·arm·数据处理指令
白太岁3 天前
操作系统开发:(11) RTOS 与 GPOS 的分界线:MMU
c语言·开发语言·汇编·arm开发·系统架构
枷锁—sha3 天前
【pwn系列】Pwndbg 汇编调试实操教程
网络·汇编·笔记·安全·网络安全