寄存器引用
引用寄存器要在寄存器前面加%如 mov %eax %eb
操作数顺序
操作数的排列是从源(左)到目的(右),如mov %eax(源), %ebx(目的)
常熟/立即数的格式
使用立即数,要在数前面加上$,如mov $4, %ebx
符号常数直接引用 如 mov value, %ebx
引用符号地址在符号前加$, 如 mov $value, %ebx
操作数长度
操作数的长度用加在指令后面的符号表示:
b(byte), w(word), l(long) 如 movw %ax,%bx
在AT&T汇编格式中,绝对转移和调用指令(jmp/call)的操作数前要加上*作为前缀
远转移指令和远调指令的操作码,在AT&T汇编格式中为"ljmp"和"lcall",而在intel格式中则为"jmp far" 和 "call far"
AT&T格式
ljmp $section, $offset
lcall $section, $offset
Intel格式
jmp far section:offset
call far section:offset
远程回指令
lret $stack_adjust
ret far stack_adjust
寻址方式
section:disp(base, index, scale)表示,计算方法是
base + index*scale + disp
section:[base + index*scale +disp]
movl -4(%ebp), %eax mov eax, [ebp - 4]
movl array(, %eax, 4), %eax mov eax, [eax*4 + array]
movw array(%ebx, %eax, 4), %cx mov cx, [ebx + 4*eax + array]
movb $4, %fs:(%eax) mov fs:eax, 4
C嵌入汇编
"a","b","c","d" 分别表示寄存器eax,ebx,ecx和edx
"S"和"D" 寄存器esi,edi
"r" 任何寄存器
"0" 与上一条语相同的寄存器