指令由操作码和操作数组成
操作数寻址方式有三大种:
立即数寻址:MOV EAX,12345678H
寄存器寻址:MOV EAX,EBX
存储器寻址:MOV EAX,DS:[20000H]
主要来看存储器寻址:
SREG:D(Rb,Ri,S) 段寄存器可用默认,省略
段址:[基地址Rb+变址Ri*比例因子S+偏移D],这三部分可以任意组合。32位以上CPU才有比例因子(1/2/4/8)。
直接寻址:MOV AX,[1000H]
寄存器间接寻址:MOV AX,[BX]
寄存器相对寻址:MOV AX,[BX+1]
基址变址寻址:MOV AX,[BX+SI]
相对基址变址寻址:MOV AX,[BX+SI+100]
比例寻址:32/64位CPU,变址不用ESP/RSP
[变址*比例因子]:MOV EAX,[EDI*4]
[变址*比例因子+偏移]:MOV EAX,[EDI*4+100]
[基址+变址*比例因子]:MOV EAX,[EBX+EDI*4]
[基址+变址*比例因子+偏移]:MOV EAX.[EBX+EDI*4+8]
Linux格式汇编:
最一般形式:D(Rb,Ri,S)
含义:Mem[Reg[Rb]+S*Reg[Ri]+ D]
索引化的寻址方式
D——常量,表示位移量(displacement): 1, 2, or 4 字节
Rb——基址寄存器(Base register): 所有16位整数寄存器
Ri——变址寄存器(Index register): 不可用%rsp
S ——比例因子(Scale): 1, 2, 4, or 8 (why these numbers?)
特殊情况
(Rb,Ri) Mem[Reg[Rb]+Reg[Ri]]
D(Rb,Ri) Mem[Reg[Rb]+Reg[Ri]+D]
(Rb,Ri,S) Mem[Reg[Rb]+S*Reg[Ri]]