算術和邏輯指令分四種:leal指令、一元操作、二元操作、移位操作。
指令 效果 描述
leal S,D D<&S 加載有效地址
INC D D<-D+1 加1
DEC D D<-D-1 減1
DEG D D<- -D 取負
NOT D D<- ~D 取補
ADD S,D D<-D+S 加
SUB S,D D<-D-S 減
LMUL S,D D<-D*S 乘
XOR S,D D<-D^S 異或
OR S,D D<-D|S 或
AND S,D D<-D&S 與
SAL k,D D<- D<<k 左移
SHL k,D D<- D<<k 等同于SAL指令
SAR k,D
D<- D>>Ak 算術右移SHR k,D
D<- D>>Lk 邏輯右移
注解:leal指令實際是mov的變形,指令形式是從存儲器到寄存器,實際上沒有引用存儲器。作用是
將有效地址寫入目的操作數。目的數必須是寄存器。
一元操作只有一個操作數,既是源又是目標數。
二元操作,兩個操作數,第一個是源,第二個是目標數。但是兩個不能同時是存儲器位置的數。
移位操作,第一個數是移位量,第二個是移位位數;移位量采用單字節編碼,允許0-31位的移位,移位量可以是立即數。
右移操作有無符號和有符號的分別,其他既可以用作無符號運算也可以用作補碼運算。
xorl %edx,%edx作用是將寄存器edx設為0,因為x,x^x=0;它等效于movl $0,%edx;兩者區別,xorl指令需要兩個字節,后者要五個字節。
其他的算術操作
指令 效果 描述
imull S R[%edx]:R[%edx] <- SxR[%edx] 有符號全64位乘法
mull S R[%edx]:R[%edx] <- SxR[%edx] 無符號全64位乘法
cltd R[%edx]:R[%edx] <- SignExtend(R[%edx]) 轉為四字節
idivl S R[%edx]:R[%edx] <- R[%edx]:R[%edx] mod S 有符號除法
R[%edx]:R[%edx] <- R[%edx]:R[%edx] ÷ S
divl S R[%edx]:R[%edx] <- R[%edx]:R[%edx] mod S 無符號除法
R[%edx]:R[%edx] <- R[%edx]:R[%edx] ÷ S
imull和mull要求其中的一個參數必須在寄存器%eax,另一個則是源操作數;%edx高32位)、%eax(低32位)
idivl將寄存器edx(高32位)和eax(低32位)中的64位數作被除數,除數是指令的操作數,商存儲在eax,余數存儲在edx中。
cltd相當于intel的cdq,將%eax符合擴展到%edx。
divl指令通常會把%edx設置為0