当前运行程序的相关信息:
以32位系统为例:
%eax %ebx %ecx %edx %edi %esi存储临时数据
%ebp %esp记录运行栈帧的地址
%eip记录即将执行指令的地址
eflag寄存器存储条件码(只有运算类指令设置条件码):
每个条件码占eflag的1位
CF:最高位向前产生的进位(无符号数算术运算溢出判定)
SF:符号标志(结果的符号位)
ZF:零标志(结果是否为0)
OF:溢出标志(有符号数算术运算溢出标志)
举例,addl Src, Dest -> t = a+b
CF set:若a+b最高位向前有进位
SF set:如果t < 0。
ZF set:如果t == 0。
OF set:如果有符号数溢出。
各种指令
cmp指令
cmpl Src, Dest:等价计算Dest - Src,但只会影响标志位,并不影响二者的值。
test指令
testl Src, Dest:等价计算Dest & Src,但只会影响标志位,不影响二者的值。
set系列指令
作用:根据eflag寄存器中的标志位,设置目的操作数为1或0,通常为8位寄存器。、
举例:
jx系列指令
cmov系列指令
作用:满足条件时,Dest = Src
举例:
这个就是如果ecx中的值 < edx中的值,那么eax中的值 = ebx中的值。