彙編指令彙總
一、數據傳輸指令
它們在存貯器和寄存器、寄存器和輸入輸出端口之間傳送數據. 1. 通用數據傳送指令. MOV 傳送字或字節. MOVSX 先符號擴展,再傳送. MOVZX 先零擴展,再傳送. PUSH 把字壓入堆棧. POP 把字彈出堆棧. PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次壓入堆棧. POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次彈出堆棧. PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次壓入堆棧. POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次彈出堆棧. BSWAP 交換32位寄存器裏字節的順序 XCHG 交換字或字節.(至少有一個操作數爲寄存器,段寄存器不可作爲操作數) CMPXCHG 比較並交換操作數.(第二個操作數必須爲累加器AL/AX/EAX) XADD 先交換再累加.(結果在第一個操作數裏) XLAT 字節查錶轉換.----BX指向一張256字節的表的起點,AL爲表的索引值(0-255,即0-FFH);返回AL爲查表結果.([BX+AL]->AL) 2. 輸入輸出端口傳送指令. IN I/O端口輸入. ( 語法: IN 累加器, {端口號│DX} ) OUT I/O端口輸出. ( 語法: OUT {端口號│DX},累加器 )輸入輸出端口由立即方式指定時, 其範圍是 0-255; 由寄存器 DX 指定時,其範圍是 0-65535. 3. 目的地址傳送指令. LEA 裝入有效地址.例: LEA DX,string ;把偏移地址存到DX. LDS 傳送目標指針,把指針內容裝入DS.例: LDS SI,string ;把段地址:偏移地址存到DS:SI. LES 傳送目標指針,把指針內容裝入ES.例: LES DI,string ;把段地址:偏移地址存到ES:DI. LFS 傳送目標指針,把指針內容裝入FS.例: LFS DI,string ;把段地址:偏移地址存到FS:DI. LGS 傳送目標指針,把指針內容裝入GS.例: LGS DI,string ;把段地址:偏移地址存到GS:DI. LSS 傳送目標指針,把指針內容裝入SS.例: LSS DI,string ;把段地址:偏移地址存到SS:DI. 4. 標誌傳送指令. LAHF 標誌寄存器傳送,把標誌裝入AH. SAHF 標誌寄存器傳送,把AH內容裝入標誌寄存器. PUSHF 標誌入棧. POPF 標誌出棧. PUSHD 32位標誌入棧. POPD 32位標誌出棧.
二、算術運算指令
加減法運算對無符號數和有符號數的處理一視同仁。即作爲無符號數而影響標誌位CF和AF,也作爲有符號數影響標識OF和SF,且總會影響ZF。加減法運算指令也要影響標誌位PF。有些指令稍有例外。 存放運算結果的操作數(兩個操作數時即左操作數)只能是通用寄存器或存儲單元(變量)。如果參與運算的操作數有兩個,則最多隻能有一個是存儲器操作數。 如果參與運算的操作數有兩個,則它們的類型必須一致,如同時爲字節或同時爲字等。 1、加法指令:add、adc、inc (1) add(Addtion) 格式:add OPRD1,OPRD2 功能:OPRD1 = OPRD1 + OPRD2 注: 影響FLAG 如:add al,5 add bl,var ;var是字節變量 add var,si ;var是字變量 (2) adc(add with Carry) ;帶進位的加法 格式:adc OPRD1,OPRD2 功能:帶進位的加法,OPRD1 = OPRD1 + OPRD2 + CF 注: 影響FLAG,主要用於多字節運算 如: adc al,[bx] adc dx,ax adc dx,var ;var是字變量 (3) inc(Increment) 格式:inc OPRD 功能:OPRD = OPRD + 1 注: 不影響CF 如:inc al inc var ;var是字節變量,也可以是字變量 inc cx 2、減法指令:sub、sbb、dec、neg、cmp (1) sub(Subtraction) 格式:sub OPRD1,OPRD2 功能:OPRD1 = OPRD1 - OPRD2 如: sub ah,12 sub bx,bp sub al,[bx] sub [BP],AX sub AX,VAR ;VAR是字變量 (2) sbb(Sub with Borrow) 格式:sbb OPRD1,OPRD2 功能:OPRD1 = OPRD1 - OPRD2 - CF 注: 主要用於多字節數相減的情況 (3) dec(decrement) 格式:dec OPRD 功能:OPRD = OPRD - 1 注: 操作數OPRD可以是通用寄存器,也可以是存儲單元。相減時把操作數作爲一個無符號數對待,這條指令影響ZF、SP、OF、PF、AF,但不影響CF,該指令主要用於調整地址指針和計數器。 (4) neg(Negate) 格式:NEG OPRD 功能:對操作數取補,即OPRD = 0 - OPRD 注: 操作數可以是通用寄存器,也可以是存儲單元。此指令結果影響CF、ZF、OF、AF、PF,一般會使CF爲1,除非OPRD=0 (5) cmp(Compare) 格式:cmp OPRD1,OPRD2 功能:執行OPRD1 - OPRD2,但運算結果不運送到OPRD1 注: 該指令通過OPRD - OPRD2影響標誌位CF、ZF、SF、OF、AF、PF來判斷OPRD1和OPRD2的大小關係。通過ZF判斷是否相等;如果是無符號數,通過CF可判斷大小;如果是有符號數,通過SF和OF判斷大小
ADD 加法. ADC 帶進位加法. INC 加 1. AAA 加法的ASCII碼調整. DAA 加法的十進制調整. SUB 減法. SBB 帶借位減法. DEC 減 1. NEG 求反(以 0 減之). CMP 比較.(兩操作數作減法,僅修改標誌位,不回送結果). AAS 減法的ASCII碼調整. DAS 減法的十進制調整. MUL 無符號乘法.結果回送AH和AL(字節運算),或DX和AX(字運算), IMUL 整數乘法.結果回送AH和AL(字節運算),或DX和AX(字運算), AAM 乘法的ASCII碼調整. DIV 無符號除法.結果回送:商回送AL,餘數回送AH, (字節運算);或 商回送AX,餘數回送DX, (字運算). IDIV 整數除法.結果回送:商回送AL,餘數回送AH, (字節運算);或 商回送AX,餘數回送DX, (字運算). AAD 除法的ASCII碼調整. CBW 字節轉換爲字. (把AL中字節的符號擴展到AH中去) CWD 字轉換爲雙字. (把AX中的字的符號擴展到DX中去) CWDE 字轉換爲雙字. (把AX中的字符號擴展到EAX中去) CDQ 雙字擴展. (把EAX中的字的符號擴展到EDX中去)
1、乘法指令:mul、imul (1) mul(Multiply) ;無符號數乘法指令 格式:MUL OPRD 功能:將OPRD與AX或AL中的操作數相乘,結果保存在DX:AX中或AX中 注: 無符號數相乘分爲16位*16位和8位*8位,結果分別爲32位和16位,保存在DX:AX中或AX中,其中結果爲32位時,DX爲高16位,AX爲低16位;結果爲16位時,AH爲高8位,AL爲低8位。 (2) imul(Signed Multiply) ;有符號數乘法指令 格式:IMUL OPRD 功能:把乘數和被乘數均作爲有符號數進行乘法運算。其餘與mul類似 注: 如果乘積結果的高位部分(DX或AH)不是低位的符號擴展,則CF=1,OF=1,否則CF=0,OF=0。即CF=1,OF=1表示AH或DX中含有結果的有效數。 如果除數爲0,或8位數除時商超過8位,16位數除時商超過16位,則認爲是除溢出,引起0號中斷。除法指令對標誌位的影響無定義。 2、除法指令:div、idiv (1) div(Division) ;無符號數除法指令 格式:DIV OPRD 功能:OPRD爲除數,被除數存放在DX:AX或AX中,做除法,結果存放在DX:AX(DX存放餘數,AX存放商)或AX(AH餘數,AL商)。 注: 8086中除法有32位除以16位和16位除以8位。前者被除數爲32位,高位在DX中,低位在AX中,除數OPRD爲16位通用寄存器或16位存儲器操作數,結果爲16位,其中16位餘數存放在DX中,16位商存放在AX中;若爲16位除以8位,被除數存放在AX中,OPRD爲8位通用寄存器或存儲器操作數,結果8位餘數存放在AH中,8位商存放在AL中。 (2) idiv(Signed Division) ;有符號數除法指令 格式:IDIV OPRD 功能:把除數和被除數看做有符號數做除法,其餘與div類似 3、符號擴展指令:cbw、cwd (1) cbw(Convert Byte to Word) 格式:CBW 功能:把寄存器AL中的符號位擴展到寄存器AH (2) cwd(Convert Word to Double Word) 格式:CWD 功能:把寄存器AX中的符號擴展到寄存器DX
三、邏輯運算指令
1、乘法指令:mul、imul (1) mul(Multiply) ;無符號數乘法指令 格式:MUL OPRD 功能:將OPRD與AX或AL中的操作數相乘,結果保存在DX:AX中或AX中 注: 無符號數相乘分爲16位*16位和8位*8位,結果分別爲32位和16位,保存在DX:AX中或AX中,其中結果爲32位時,DX爲高16位,AX爲低16位;結果爲16位時,AH爲高8位,AL爲低8位。 (2) imul(Signed Multiply) ;有符號數乘法指令 格式:IMUL OPRD 功能:把乘數和被乘數均作爲有符號數進行乘法運算。其餘與mul類似 注: 如果乘積結果的高位部分(DX或AH)不是低位的符號擴展,則CF=1,OF=1,否則CF=0,OF=0。即CF=1,OF=1表示AH或DX中含有結果的有效數。 如果除數爲0,或8位數除時商超過8位,16位數除時商超過16位,則認爲是除溢出,引起0號中斷。除法指令對標誌位的影響無定義。 2、除法指令:div、idiv (1) div(Division) ;無符號數除法指令 格式:DIV OPRD 功能:OPRD爲除數,被除數存放在DX:AX或AX中,做除法,結果存放在DX:AX(DX存放餘數,AX存放商)或AX(AH餘數,AL商)。 注: 8086中除法有32位除以16位和16位除以8位。前者被除數爲32位,高位在DX中,低位在AX中,除數OPRD爲16位通用寄存器或16位存儲器操作數,結果爲16位,其中16位餘數存放在DX中,16位商存放在AX中;若爲16位除以8位,被除數存放在AX中,OPRD爲8位通用寄存器或存儲器操作數,結果8位餘數存放在AH中,8位商存放在AL中。 (2) idiv(Signed Division) ;有符號數除法指令 格式:IDIV OPRD 功能:把除數和被除數看做有符號數做除法,其餘與div類似 3、符號擴展指令:cbw、cwd (1) cbw(Convert Byte to Word) 格式:CBW 功能:把寄存器AL中的符號位擴展到寄存器AH (2) cwd(Convert Word to Double Word) 格式:CWD 功能:把寄存器AX中的符號擴展到寄存器DX
AND 與運算. OR 或運算. XOR 異或運算. NOT 取反. TEST 測試.(兩操作數作與運算,僅修改標誌位,不回送結果). SHL 邏輯左移. SAL 算術左移.(=SHL) SHR 邏輯右移. SAR 算術右移.(=SHR) ROL 循環左移. ROR 循環右移. RCL 通過進位的循環左移. RCR 通過進位的循環右移. 以上八種移位指令,其移位次數可達255次. 移位一次時, 可直接用操作碼. 如 SHL AX,1. 移位>1次時, 則由寄存器CL給出移位次數. 如 MOV CL,04 SHL AX,CL
四、串指令
DS:SI 源串段寄存器 :源串變址. ES:DI 目標串段寄存器:目標串變址. CX 重複次數計數器. AL/AX 掃描值. D標誌 0表示重複操作中SI和DI應自動增量; 1表示應自動減量. Z標誌 用來控制掃描或比較操作的結束. MOVS 串傳送.( MOVSB 傳送字符. MOVSW 傳送字. MOVSD 傳送雙字. ) CMPS 串比較.( CMPSB 比較字符. CMPSW 比較字. ) SCAS 串掃描.把AL或AX的內容與目標串作比較,比較結果反映在標誌位. LODS 裝入串.把源串中的元素(字或字節)逐一裝入AL或AX中.( LODSB 傳送字符. LODSW 傳送字. LODSD 傳送雙字. ) STOS 保存串.是LODS的逆過程. REP 當CX/ECX<>0時重複. REPE/REPZ 當ZF=1或比較結果相等,且CX/ECX<>0時重複. REPNE/REPNZ 當ZF=0或比較結果不相等,且CX/ECX<>0時重複. REPC 當CF=1且CX/ECX<>0時重複. REPNC 當CF=0且CX/ECX<>0時重複.
五、程序轉移指令
1、無條件轉移指令:JMP(Jump) 段內轉移:改變IP 段間轉移:改變CS:IP (1) 無條件段內直接轉移指令 格式:JMP 標號 功能:使控制無條件轉移至標號地址處 原理:把編譯時計算出的地址差加到IP上 (2) 無條件段內間接轉移指令 格式:JMP OPRD 功能:使控制指令無條件轉移到OPRD的內容給定的目標地址處。操作數OPRD可以是通用寄存器,也可以是字存儲單元 例如:jmp cx ;CX寄存器的內容送IP jmp word ptr [1234h] ;字存儲單元[1234h]的內容送IP (3) 無條件段間直接轉移指令 格式:jmp far ptr 標號 功能:使控制指令無條件的轉移到標號對應的地址處 原理:把編譯時產生的標號處的段地址和偏移地址分別置入CS和IP (4) 無條件段間間接轉移指令 格式:JMP OPRD 功能:使控制指令無條件轉移到操作數OPRD的內容給定的目標地址處。操作數OPRD必須是雙字存儲單元 例如:jmp dword ptr [1234h] ;雙字存儲單元的低字內容送IP,高字內容送CS 2、條件轉移指令 3、循環指令:LOOP、LOOPE/LOOPZ、LOOPNE/LOOPNZ、JCXZ (1) Loop ;計數循環指令 格式:loop 標號 功能:使轉移標號與Loop指令間的指令循環執行CX次 原理:指令執行至loop時,cx減1,如果cx不爲0,則跳轉至標號處,否則繼續執行下一條指令 即:DEC CX JNZ 標號 (2) LOOPE/LOOPZ ;等於/全零循環指令 格式:LOOPE 標號 LOOPZ 標號 功能:該指令使CX自減1,若結果不爲0,並且ZF=1,則轉移至標號,否則順序執行。注意指令本身實施的CX自減1操作不影響標誌 (3) LOOPNE/LOOPNZ ;不等於/非零循環指令 格式:LOOPNE 標號 LOOPNZ 標號 功能:該指令使CX自減1,若結果不爲0,並且ZF=0,則轉移至標號,否則順序執行。注意指令本身實施的CX自減1操作不影響標誌 (4) JCXZ ;跳轉指令 格式:JCXZ 標號 功能:當寄存器CX的值爲0時跳轉到標號,否則順序執行
1. 無條件轉移指令 (長轉移) JMP 無條件轉移指令 CALL 過程調用 RET/RETF 過程返回. 2. 條件轉移指令 (短轉移,-128到+127的距離內)( 當且僅當(SF XOR OF)=1時,OP1<OP2 ) JA/JNBE 不小於或不等於時轉移. JAE/JNB 大於或等於轉移. JB/JNAE 小於轉移. JBE/JNA 小於或等於轉移. 以上四條,測試無符號整數運算的結果(標誌C和Z). JG/JNLE 大於轉移. JGE/JNL 大於或等於轉移. JL/JNGE 小於轉移. JLE/JNG 小於或等於轉移. 以上四條,測試帶符號整數運算的結果(標誌S,O和Z). JE/JZ 等於轉移. JNE/JNZ 不等於時轉移. JC 有進位時轉移. JNC 無進位時轉移. JNO 不溢出時轉移. JNP/JPO 奇偶性爲奇數時轉移. JNS 符號位爲 "0" 時轉移. JO 溢出轉移. JP/JPE 奇偶性爲偶數時轉移. JS 符號位爲 "1" 時轉移. 3. 循環控制指令(短轉移) LOOP CX不爲零時循環. LOOPE/LOOPZ CX不爲零且標誌Z=1時循環. LOOPNE/LOOPNZ CX不爲零且標誌Z=0時循環. JCXZ CX爲零時轉移. JECXZ ECX爲零時轉移. 4. 中斷指令 INT 中斷指令 INTO 溢出中斷 IRET 中斷返回 5. 處理器控制指令 HLT 處理器暫停, 直到出現中斷或復位信號才繼續. WAIT 當芯片引線TEST爲高電平時使CPU進入等待狀態. ESC 轉換到外處理器. LOCK 封鎖總線. NOP 空操作. STC 置進位標誌位. CLC 清進位標誌位. CMC 進位標誌取反. STD 置方向標誌位. CLD 清方向標誌位. STI 置中斷允許位. CLI 清中斷允許位.
六、僞指令
DW 定義字(2字節).
PROC 定義過程.
ENDP 過程結束.
SEGMENT 定義段.
ASSUME 建立段寄存器尋址.
ENDS 段結束.
END 程序結束.
七、處理機控制指令:標誌處理指令
1、標誌傳送指令:LAHF(Load AH with Flags)、SAHF(Store AH into Flags)、PUSHF、POPF (1) LAHF(Load AH with Flags) 格式:LAHF 功能:把標誌寄存器的低8位(包括SF(7)、ZF(6)、AF(4)、PF(2)、CF(0))傳送到AH指定位。 (2) SAHF(Store AH into Flags) 格式:SAHF 功能:把寄存器AH的指定位送至標誌寄存器低8位(包括SF(7)、ZF(6)、AF(4)、PF(2)、CF(0))。 (3) PUSHF 格式:PUSHF 功能:把標誌寄存器的內容(16位)壓入堆棧。SP-=2 注: 這條指令不影響標誌位 (4) POPF 格式:POPF 功能:把當前棧頂的一個字傳送到標誌寄存器。SP+=2 2、標誌位操作指令:CLC、STC、CMC、CLD、STD、CLI、STI (1) CLC(Clear Carry Flag): CF置0 (2) STC(Set Carry Flag): CF置1 (3) CMC(Complement Carry Flag): CF取反 (4) CLD(Clear Direction Flag): DF置0,執行串操作指令時,地址遞增 (5) STD(Set Direction Flag): DF置1,執行串操作指令時,地址遞減 (6) CLI(Clear Interrupt enable Flag) IF置0,使CPU不響應來自外部裝置的可屏蔽中斷,但對不可屏蔽中斷和內部中斷沒有影響 (7) STI(Set Interrupt enable Flag) IF置1,可以響應可屏蔽中斷
CLC 進位位置0指令
CMC 進位位求反指令
STC 進位位置爲1指令
CLD 方向標誌置1指令
STD 方向標誌位置1指令
CLI 中斷標誌置0指令
STI 中斷標誌置1指令
NOP 無操作
HLT 停機
WAIT 等待
ESC 換碼
LOCK 封鎖
浮點運算指令集
一、控制指令
(帶9B的控制指令前綴F變爲FN時浮點不檢查,機器碼去掉9B)
FINIT 初始化浮點部件 機器碼 9B DB E3 FCLEX 清除異常 機器碼 9B DB E2 FDISI 浮點檢查禁止中斷 機器碼 9B DB E1 FENI 浮點檢查禁止中斷二 機器碼 9B DB E0 WAIT 同步CPU和FPU 機器碼 9B FWAIT 同步CPU和FPU 機器碼 D9 D0 FNOP 無操作 機器碼 DA E9 FXCH 交換ST(0)和ST(1) 機器碼 D9 C9 FXCH ST(i) 交換ST(0)和ST(i) 機器碼 D9 C1iii FSTSW ax 狀態字到ax 機器碼 9B DF E0 FSTSW word ptr mem 狀態字到mem 機器碼 9B DD mm111mmm FLDCW word ptr mem mem到狀態字 機器碼 D9 mm101mmm FSTCW word ptr mem 控制字到mem 機器碼 9B D9 mm111mmm FLDENV word ptr mem mem到全環境 機器碼 D9 mm100mmm FSTENV word ptr mem 全環境到mem 機器碼 9B D9 mm110mmm FRSTOR word ptr mem mem到FPU狀態 機器碼 DD mm100mmm FSAVE word ptr mem FPU狀態到mem 機器碼 9B DD mm110mmm FFREE ST(i) 標誌ST(i)未使用 機器碼 DD C0iii FDECSTP 減少棧指針1->0 2->1 機器碼 D9 F6 FINCSTP 增加棧指針0->1 1->2 機器碼 D9 F7 FSETPM 浮點設置保護 機器碼 DB E4
二、數據傳送指令
1、傳送指令:MOV (move) 格式:mov dst,src 具體用法: (1) CPU內部寄存器之間的數據傳送,如:mov ah,al (2) 立即數送至通用寄存器(非段寄存器)或存儲單元,如:mov al,3 mov [bx],1234h (3) 寄存器與存儲器間的數據傳送,如:mov ax,var mov ax,[bx] 2、交換指令:XCHG xchg OPRD1,OPRD2 ;OPRD可以是通用寄存器或存儲單元,但不包括段寄存器,不能同時是存儲單元,不能有立即數 3、地址傳送指令:LEA、LDS、LES (1) LEA(Load Effective Address) 格式: lea REG,OPRD 功能: 把操作數OPRD的有效地址傳送到操作數REG 注: REG必須是16位通用寄存器,OPRD必須是一個存儲器操作數 如: lea ax,buf ;buf是變量名 lea ax,[si+2] (2) LDS(Load pointer into DS) 格式: lds REG,OPRD 功能: 傳送32位地址指針,將OPRD存儲的32位數的高16位(段地址)送至DS,低16位(偏移地址)送至REG。(注意OPRD存放的32位數據,不是OPRD本身的地址) 注: 操作數OPRD必須是一個32位存儲器操作數,操作數REG可以時16位通用寄存器,但通常是指令指針寄存器(IP)或變址寄存器(SI,DI,SP,BP) 如: lds di,[bx] lds si,FARPOINTER ;FARPOINTER是一個32位(雙字)變量 (3) LES(Load pointer into ES) 格式: les REG,OPRD 功能: 把操作數OPRD存儲的32位數據的高16位(段地址)送至ES,低16位(偏移地址)送至REG 其他同LDS
FLDZ 將0.0裝入ST(0) 機器碼 D9 EE FLD1 將1.0裝入ST(0) 機器碼 D9 E8 FLDPI 將π裝入ST(0) 機器碼 D9 EB FLDL2T 將ln10/ln2裝入ST(0) 機器碼 D9 E9 FLDL2E 將1/ln2裝入ST(0) 機器碼 D9 EA FLDLG2 將ln2/ln10裝入ST(0) 機器碼 D9 EC FLDLN2 將ln2裝入ST(0) 機器碼 D9 ED FLD real4 ptr mem 裝入mem的單精度浮點數 機器碼 D9 mm000mmm FLD real8 ptr mem 裝入mem的雙精度浮點數 機器碼 DD mm000mmm FLD real10 ptr mem 裝入mem的十字節浮點數 機器碼 DB mm101mmm FILD word ptr mem 裝入mem的二字節整數 機器碼 DF mm000mmm FILD dword ptr mem 裝入mem的四字節整數 機器碼 DB mm000mmm FILD qword ptr mem 裝入mem的八字節整數 機器碼 DF mm101mmm FBLD tbyte ptr mem 裝入mem的十字節BCD數 機器碼 DF mm100mmm FST real4 ptr mem 保存單精度浮點數到mem 機器碼 D9 mm010mmm FST real8 ptr mem 保存雙精度浮點數到mem 機器碼 DD mm010mmm FIST word ptr mem 保存二字節整數到mem 機器碼 DF mm010mmm FIST dword ptr mem 保存四字節整數到mem 機器碼 DB mm010mmm FSTP real4 ptr mem 保存單精度浮點數到mem並出棧 機器碼 D9 mm011mmm FSTP real8 ptr mem 保存雙精度浮點數到mem並出棧 機器碼 DD mm011mmm FSTP real10 ptr mem 保存十字節浮點數到mem並出棧 機器碼 DB mm111mmm FISTP word ptr mem 保存二字節整數到mem並出棧 機器碼 DF mm011mmm FISTP dword ptr mem 保存四字節整數到mem並出棧 機器碼 DB mm011mmm FISTP qword ptr mem 保存八字節整數到mem並出棧 機器碼 DF mm111mmm FBSTP tbyte ptr mem 保存十字節BCD數到mem並出棧 機器碼 DF mm110mmm FCMOVB ST(0),ST(i) <時傳送 機器碼 DA C0iii FCMOVBE ST(0),ST(i) <=時傳送 機器碼 DA D0iii FCMOVE ST(0),ST(i) =時傳送 機器碼 DA C1iii FCMOVNB ST(0),ST(i) >=時傳送 機器碼 DB C0iii FCMOVNBE ST(0),ST(i) >時傳送 機器碼 DB D0iii FCMOVNE ST(0),ST(i) !=時傳送 機器碼 DB C1iii FCMOVNU ST(0),ST(i) 有序時傳送 機器碼 DB D1iii FCMOVU ST(0),ST(i) 無序時傳送 機器碼 DA D1iii
三、比較指令
FCOM ST(0)-ST(1) 機器碼 D8 D1 FCOMI ST(0),ST(i) ST(0)-ST(1) 機器碼 DB F0iii FCOMIP ST(0),ST(i) ST(0)-ST(1)並出棧 機器碼 DF F0iii FCOM real4 ptr mem ST(0)-實數mem 機器碼 D8 mm010mmm FCOM real8 ptr mem ST(0)-實數mem 機器碼 DC mm010mmm FICOM word ptr mem ST(0)-整數mem 機器碼 DE mm010mmm FICOM dword ptr mem ST(0)-整數mem 機器碼 DA mm010mmm FICOMP word ptr mem ST(0)-整數mem並出棧 機器碼 DE mm011mmm FICOMP dword ptr mem ST(0)-整數mem並出棧 機器碼 DA mm011mmm FTST ST(0)-0 機器碼 D9 E4 FUCOM ST(i) ST(0)-ST(i) 機器碼 DD E0iii FUCOMP ST(i) ST(0)-ST(i)並出棧 機器碼 DD E1iii FUCOMPP ST(0)-ST(1)並二次出棧 機器碼 DA E9 FXAM ST(0)規格類型 機器碼 D9 E5
四、運算指令
FADD 把目的操作數 (直接接在指令後的變量或堆棧緩存器) 與來源操作數 (接在目的操作數後的變量或堆棧緩存器) 相加,並將結果存入目的操作數 FADDP ST(i),ST 這個指令是使目的操作數加上 ST 緩存器,並彈出 ST 緩存器,而目的操作數必須是堆棧緩存器的其中之一,最後不管目的操作數爲何,經彈出一次後,目的操作數會變成上一個堆棧緩存器了 FIADD FIADD 是把 ST 加上來源操作數,然後再存入 ST 緩存器,來源操作數必須是字組整數或短整數形態的變數 FSUB 減 FSUBP FSUBR 減數與被減數互換 FSUBRP FISUB FISUBR FMUL 乘 FMULP FIMUL FDIV 除 FDIVP FDIVR FDIVRP FIDIV FIDIVR FCHS 改變 ST 的正負值 FABS 把 ST 之值取出,取其絕對值後再存回去。 FSQRT 將 ST 之值取出,開根號後再存回去。 FSCALE 這個指令是計算 ST*2^ST(1)之值,再把結果存入 ST 裏而 ST(1) 之值不變。ST(1) 必須是在 -32768 到 32768 (-215 到 215 )之間的整數,如果超過這個範圍計算結果無法確定,如果不是整數 ST(1) 會先向零舍入成整數再計算。所以爲安全起見,最好是由字組整數載入到 ST(1) 裏。 FRNDINT 這個指令是把 ST 的數值舍入成整數,FPU 提供四種舍入方式,由 FPU 的控制字組(control word)中的 RC 兩個位決定 RC 舍入控制 00 四捨五入 01 向負無限大舍入 10 向正無限大舍入 11 向零捨去
五、堆棧操作指令
1、進棧指令:push 格式:push src 功能: 把16位數據src壓入堆棧。 注: 源操作數src可以是通用寄存器和段寄存器,也可以是字存儲單元 如: push si push [si] push var ;var是16位(字)變量 2、出棧指令:pop 格式:pop dst 功能:從堆棧彈出16位數據至dst 注: dst可以是通用寄存器和段寄存器,但不能是CS,可以是字存儲單元 如: pop si pop [si] pop var ;var是字變量