1. 程式人生 > >OllyDbg命令列命令+彙編指令大全

OllyDbg命令列命令+彙編指令大全

OllyDbg命令列命令


以下命令適用於 OllyDbg 的命令列外掛 Cmdline.dll(顯示於程式的外掛選單中)
===============================================================
命令列外掛支援的命令

CALC
判斷表示式

WATCH
新增監視表示式

AT
在指定地址進行反彙編

FOLLOW
跟隨命令

ORIG
反彙編於 EIP

DUMP
在指定地址進行轉存

DA
轉存為反彙編程式碼

DB
使用十六進位制位元組格式轉存

DC
使用 ASCII 格式轉存

DD
轉存在堆疊格式

DU
轉存在 UNICODE 格式

DW
使用十六進位制字詞格式轉存

STK
前往堆疊中的地址

AS
(AS 地址 字串)
在指定地址進行彙編

BP
進行條件中斷(有條件的斷點)

BPX
中斷在全部呼叫 (Call)

BPD
清除全部呼叫中的斷點

BC
清除斷點

MR
記憶體斷點於訪問時

MW
記憶體斷點於寫入時

MD
清除記憶體斷點

HR
訪問時進行硬體中斷

HW
寫入時進行硬體中斷

HE
執行時進行硬體中斷

HD
清除硬體斷點

STOP
停止執行程式除錯

PAUSE
暫停執行程式除錯

RUN
執行程式進行除錯

GE
執行和通過例外

SI
單步進入 Call 中

SO
步過 Call

TI
跟蹤進入直到地址

TO
跟蹤步過直到地址

TC
跟蹤進入直到滿足條件

TOC
跟蹤步過直到滿足條件

TR
執行直到返回

TU
執行直到使用者程式碼

LOG
檢視記錄視窗

MOD
檢視模組視窗

MEM
檢視記憶體視窗

CPU
檢視 CPU 視窗

CS
檢視 Call 堆疊

BRK
檢視斷點視窗

OPT
開啟選項設定視窗

EXIT
退出 OllyDbg

QUIT
退出 OllyDbg

OPEN
開啟一個可執行檔案

CLOSE
關閉可執行檔案

RST
重新運行當前程式

HELP
檢視 API 函式的幫助


以下命令適用於 OllyDbg 的快捷命令欄外掛(顯示於程式的狀態列上方) 
======================================================== 
CALC 
判斷表示式

WATCH 
新增監視表示式

AT / FOLLOW 
Disassemble at address 
在地址進行反彙編

ORIG 
Disassemble at EIP 
反彙編於 EIP

DUMP 
Dump at address 
在地址轉存

DA 
Dump as disassembly 
轉存為反彙編程式碼

DB 
Dump in hex byte format 
轉存在十六進位制位元組格式

DC 
Dump in ASCII format 
轉存在 ASCII 格式

DD 
Dump in stack format 
轉存在堆疊格式

DU 
Dump in UNICODE format 
轉存在 UNICODE 格式

DW 
Dump in hex word format 
轉存在十六進位制字詞格式

STK 
Go to address in stack 
前往堆疊中的地址

AS + 地址 + 字串 
Assemble at address 
在地址進行彙編

L + 地址 + 字串 
Label at address 
在地址進行標號

C + 地址 + 字串 
Comment at address 
在地址進行註釋

BP 
Break with condition 
使用條件中斷

BPX 
Break on all calls 
中斷在全部呼叫

BPD 
Delete break on all calls 
清除位於全部呼叫的斷點

BC 
Delete breakpoint 
清除斷點

MR 
Memory breakpt on access 
記憶體斷點於訪問時

MW 
Memory breakpt on write 
記憶體斷點於寫入時

MD 
Remove memory breakpoint 
清除記憶體斷點

HR 
HW break on access 
硬體中斷在訪問

HW 
HW break on write 
硬體中斷在寫入

HE 
HW break on execution 
硬體中斷在執行

HD 
Remove HW breakpoint 
清除硬體斷點

STOP 
Pause execution 
暫停執行 
PAUSE 
PAUSE

RUN 
Run program 
執行程式 
Run till address 
執行到地址

GE 
Run and pass exception 
執行和通過例外

SI 
Step into 
步入


SO 
Step over 
步過

TI 
Trace in till address 
跟蹤進入直到地址

TO 
Trace over till address 
跟蹤步過直到地址

TC 
Trace in till condition 
跟蹤進入直到條件

TOC 
Trace over till condition 
跟蹤步過直到條件

TR 
Till return 
直到返回

TU 
Till user code 
直到使用者程式碼

LOG 
View Log window 
檢視記錄視窗

MOD 
View Modules window 
檢視模組視窗

MEM 
View Memory window 
檢視記憶體視窗

CPU 
View CPU window 
檢視 CPU 視窗

CS 
View Call Stack 
檢視 Call 堆疊

BRK 
View Breakpoints window 
檢視斷點視窗

OPT 
Open Options 
開啟選項

EXIT / QUIT 
Quit OllyDbg 
退出 OllyDbg

OPEN 
Open executable file 
開啟可執行檔案

CLOSE 
Close executable 
關閉程式

RST 
Restart current program 
恢復當前程式

HELP 
Help on API function 
API 函式的幫助

ASM 
Assemble (if command needs it's own addres, /"ASM COMMAND;ADDRESS/") 
彙編 (如果命令需要自身的地址 /"ASM COMMAND;ADDRESS/")

DASM 
Disassemble immediate opcode 
反彙編直接的機器碼

FR 
Find reference to selected command/address 
查詢參考到選定的命令/地址

AC 
Analyse code 
分析程式碼

SN 
Search for Name(label) in current module 
在當前模組中搜索名稱(標號)

SOB 
Scan object files 
掃描專案檔案 
彙編指令大全

一、資料傳送指令
1.通用資料傳送指令
MOV(Move)傳送
PUSH(Push onto the stack)進棧
POP(Pop from the stack)出棧
XCHG(Exchange)交換
.MOV指令
格式為: MOV   DST,SRC
執行的操作:(DST)<-(SRC)
.PUSH進棧指令
格式為:PUSH   SRC
執行的操作:(SP)<-(SP)-2
            ((SP)+1,(SP))<-(SRC)
.POP出棧指令
格式為:POP   DST
執行的操作:(DST)<-((SP+1),(SP))
            (SP)<-(SP)+2
.XCHG 交換指令
格式為:XCHG   OPR1,OPR2
執行的操作:(OPR1)<-->(OPR2)

2.累加器專用傳送指令
IN(Input)   輸入
OUT(Output)   輸出
XLAT(Translate)   換碼
這組指令只限於使用累加器AX或AL傳送資訊.
.IN 輸入指令
長格式為:     IN   AL,PORT(位元組)
      IN   AX,PORT(字)
執行的操作:   (AL)<-(PORT)(位元組)
              (AX)<-(PORT+1,PORT)(字)
短格式為:     IN   AL,DX(位元組)
              IN   AX,DX(字)
執行的操作:   AL<-((DX))(位元組)
              AX<-((DX)+1,DX)(字)
.OUT 輸出指令
長格式為:     OUT   PORT,AL(位元組)
              OUT    PORT,AX(字)
執行的操作:   (PORT)<-(AL)(位元組)
              (PORT+1,PORT)<-(AX)(字)
短格式為:     OUT   DX,AL(位元組)
              OUT   DX,AX(字)
執行的操作:   ((DX))<-(AL)(位元組)
              ((DX)+1,(DX))<-AX(字)
     在IBM-PC機裡,外部裝置最多可有65536個I/O埠,埠(即外設的埠地址)為0000~FFFFH.其中前256個埠(0~FFH)可以 直接在指令中指定,這就是長格式中的PORT,此時機器指令用二個位元組表示,第二個位元組就是埠號.所以用長格式時可以在指定中直接指定埠號,但只限於 前256個埠.當埠號>=256時,只能使用短格式,此時,必須先把埠號放到DX暫存器中(埠號可以從0000到0FFFFH),然後再用 IN或OUT指令來 傳送資訊. 
.XLAT   換碼指令
格式為:     XLAT   OPR
或:         XLAT
執行的操作:(AL)<-((BX)+(AL))

3.有效地址送暫存器指令
LEA(Load effective address)有效地址送暫存器
LDS(Load DS with Pointer)指標送暫存器和DS
LES(Load ES with Pointer)指標送暫存器和ES
.LEA 有效地址送暫存器
格式為:   LEA    REG,SRC
執行的操作:(REG)<-SRC
     指令把源運算元的有效地址送到指定的暫存器中.
.LDS 指標送暫存器和DS指令
格式為:   LDS   REG,SRC
執行的操作:(REG)<-(SRC)
            (DS)<-(SRC+2)
     把源運算元指定的4個相繼位元組送到由指令指定的暫存器及DS暫存器中.該指令常指定SI暫存器.
.LES 指標送暫存器和ES指令
格式為:   LES   REG,SRC
執行的操作: (REG)<-(SRC)
             (ES)<-(SRC+2)
     把源運算元指定的4個相繼位元組送到由指令指定的暫存器及ES暫存器中.該指令常指定DI暫存器.

4.標誌暫存器傳送指令
LAHF(Load AH with flags)標誌送AH
SAHF(store AH into flags)AH送標誌暫存器
PUSHF(push the flags) 標誌進棧
POPF(pop the flags) 標誌出棧
.LAHF 標誌送AH
格式為:     LAHF
執行的操作:(AH)<-(PWS的低位元組)
.SAHF AH送標誌暫存器
格式為:     SAHF
執行的操作:(PWS的低位元組)<-(AH)
.PUSHF 標誌進棧
格式為:     PUSHF
執行的操作:(SP)<-(SP)-2
            ((SP)+1,(SP))<-(PSW)
.POPF 標誌出棧
格式為:     POPF
執行的操作:(PWS)<-((SP)+1,(SP))
            (SP)<-(SP+2)

二、算術指令
1.加法指令
ADD(add)加法
ADC(add with carry)帶進位加法
INC(increment)加1
.ADD   加法指令
格式:     ADD    DST,SRC
執行的操作:(DST)<-(SRC)+(DST)
.ADC   帶進位加法指令
格式:     ADC    DST,SRC
執行的操作:(DST)<-(SRC)+(DST)+CF
.ADD   加1指令
格式:     INC    OPR
執行的操作:(OPR)<-(OPR)+1

2.減法指令
SUB(subtract)減法
SBB(subtract with borrow)帶借位減法
DEC(Decrement)減1
NEG(Negate)求補
CMP(Compare)比較
.SUB   減法指令
格式:   SUB   DST,SRC
執行的操作:(DST)<-(DST)-(SRC)
.SBB   帶借位減法指令
格式:   SBB   DST,SRC
執行的操作:(DST)<-(DST)-(SRC)-CF
.DEC   減1指令
格式:   DEC   OPR
執行的操作:(OPR)<-(OPR)-1
.NEG   求補指令
格式:   NEG   OPR
執行的操作:(OPR)<- -(OPR)
.CMP   比較指令
格式:   CMP   OPR1,OPR2
執行的操作:(OPR1)-(OPR2)
     該指令與SUB指令一樣執行減法操作,但不儲存結果,只是根據結果設定條件標誌西半球.

3.乘法指令
MUL(Unsigned Multiple)無符號數乘法
IMUL(Signed Multiple)帶符號數乘法
.MUL 無符號數乘法指令
格式:    MUL   SRC
執行的操作:
     位元組運算元:(AX)<-(AL)*(SRC)
     字運算元:(DX,AX)<-(AX)*(SRC)
.IMUL 帶符號數乘法指令
格式:    IMUL   SRC
執行的操作:與MUL相同,但必須是帶符號數,而MUL是無符號數.

4.除法指令
DIV(Unsigned divide)無符號數除法
IDIV(Signed divide)帶符號數除法

CBW(Convert byte to word)位元組轉換為字
CWD(Contert word to double word)字轉換為雙字
.DIV   無符號數除法指令
格式:    DIV   SRC
執行的操作:
位元組操作:(AL)<-(AX)/(SRC)的商
            (AH)<-(AX)/(SRC)的餘數
   字操作:   (AX)<-(DX,AX)/(SRC)的商
            (AX)<-(DX,AX)/(SRC)的餘數
.IDIV   帶符號數除法指令
格式:    DIV   SRC
執行的操作:與DIV相同,但運算元必須是帶符號數,商和餘數也均為帶符號數,且餘數的符號與被除數的符號相同.
.CBW 位元組轉換為字指令
格式:    CBW
執行的操作:AL的內容符號擴充套件到AH.即如果(AL)的最高有效位為0,則(AH)=00;如(AL)的最高有效位為1,則(AH)=0FFH
.CWD 字轉換為雙字指令
格式:   CWD
執行的操作:AX的內容符號擴充套件到DX.即如(AX)的最高有效位為0,則(DX)=0;否則(DX)=0FFFFH.
     這兩條指令都不影響條件碼.

三、邏輯指令
1.邏輯運算指令
AND(and)           邏輯與
OR(or)            邏輯或
NOT(not)          邏輯非
XOR(exclusive or)異或
TEST(test)        測試
.AND   邏輯與指令
格式:     AND    DST,SRC
執行的操作:(DST)<-(DST)^(SRC)
.OR   邏輯或指令
格式:     OR    DST,SRC
執行的操作:(DST)<-(DST)V(SRC)
.NOT   邏輯非指令
格式:     NOT    OPR
執行的操作:(OPR)<-(OPR)
.XOR   異或指令
格式:     XOR    DST,SRC
執行的操作:(DST)<-(DST)V(SRC)
.TEST   測試指令
格式:     TEST    OPR1,OPR2
執行的操作:(DST)^(SRC)
兩個運算元相與的結果不儲存,只根據其特徵置條件碼

2.移位指令
SHL(shift logical left)           邏輯左移
SAL(shift arithmetic left)       算術左移
SHR(shift logical right)         邏輯右移
SAR(shift arithmetic right)      算術右移
ROL(Rotate left)                  迴圈左移
ROR(Rotate right)                 迴圈右移
RCL(Rotate left through carry)   帶進位迴圈左移
RCR(Rotate right through carry) 帶進位迴圈右移
格式:     SHL   OPR,CNT(其餘的類似)
其中OPR可以是除立即數以外的任何定址方式.移位次數由CNT決定,CNT可以是1或CL.
     迴圈移位指令可以改變運算元中所有位的位置;移位指令則常常用來做乘以2除以2操作.其中算術移位指令適用於帶符號數運算,SAL用來乘2,SAR用來除以2;而邏輯移位指令則用來無符號數運算,SHL用來乘2,SHR用來除以2.

四、串處理指令
1.與REP相配合工作的MOVS,STOS和LODS指令
.REP重複串操作直到(CX)=0為上
格式: REP    string primitive
其中String Primitive可為MOVS,LODS或STOS指令
執行的操作:
1)如(CX)=0則退出REP,否則往下執行.
2)(CX)<-(CX)-1
3)執行其中的串操作
4)重複1)~3)
.MOVS   串傳送指令
格式:可有三種
    MOVS   DST,SRC
     MOVSB(位元組)
     MOVSW(字)
其中第二、三種格式明確地註明是傳送位元組或字,第一種格式則應在運算元中表明是字還是位元組操作,例如:
            MOVS     ES:BYTE PTR[DI],DS:[SI]
執行的操作:
1)((DI))<-((SI))
2)位元組操作:
    (SI)<-(SI)+(或-)1,(DI)<-(DI)+(或-)1
    當方向標誌DF=0時用+,當方向標誌DF=1時用-
3)字操作:
    (SI)<-(SI)+(或-)2,(DI)<-(DI)+(或-)2
    當方向標誌DF=0時用+,當方向標誌DF=1時用-
該指令不影響條件碼.
.CLD(Clear direction flag)該指令使DF=0,在執行串操作指令時可使地址自動增量;
.STD(Set direction flag)該指令使DF=1,在執行串操作指令時可使地址自動減量.
.STOS   存入串指令
格式:    STOS   DST
         STOSB(位元組)
         STOSW(字)
執行的操作:
    位元組操作:((DI))<-(AL),(DI)<-(DI)+-1 
    字操作:   ((DI))<-(AX),(DI)<-(DI)+-2
該指令把AL或AX的內容存入由(DI)指定的附加段的某單元中,並根據DF的值及資料型別修改DI的內容,當它與REP聯用時,可把AL或AX的內容存入一個長度為(CX)的緩衝區中.
.LODS   從串取指令
格式:     LODS   SRC
          LODSB
          LODSW
執行的操作:
    位元組操作:(AL)<-((SI)),(SI)<-(SI)+-1
     字操作: (AX)<-((SI)),(SI)<-(SI)+-2
該指令把由(SI)指定的資料段中某單元的內容送到AL或AX中,並根據方向標誌及資料型別修改SI的內容.指令允許使用段跨越字首來指定非資料段的儲存區.該指令也不影響條件碼.
     一般說來,該指令不和REP聯用.有時緩衝區中的一串字元需要逐次取出來測試時,可使用本指令.
   
2.與REPE/REPZ和REPNZ/REPNE聯合工作的CMPS和SCAS指令
.REPE/REPZ   當相等/為零時重複串操作
格式:      REPE(或REPZ)     String Primitive
其中String Primitive可為CMPS或SCAS指令.
執行的操作:
1)如(CX)=0或ZF=0(即某次比較的結果兩個運算元不等)時退出,否則往下執行
2)(CX)<-(CX)-1
3)執行其後的串指令
4)重複1)~3)
.REPNE/REPNZ   當不相等/不為零時重複串操作
格式:      REPNE(或REPNZ)    String Primitive
其中String Primitive可為CMPS或SCAS指令
執行的操作:
     除退出條件(CX=0)或ZF=1外,其他操作與REPE完全相同.
.CMPS   串比較指令
格式:      CMP    SRC,DST
           CMPSB
           CMPSW
執行的操作:
1)((SI))-((DI))
2)位元組操作:(SI)<-(SI)+-1,(DI)<-(DI)+-1
   字操作:   (SI)<-(SI)+-2,(DI)<-(DI)+-2 
指令把由(SI)指向的資料段中的一個字(或位元組)與由(DI)指向的附加段中的一個字(或位元組)相減,但不儲存結果,只根據結果設定條件碼,指令的其它特性和MOVS指令的規定相同.
.SCAS   串掃描指令
格式:    SCAS    DST
         SCASB
         SCASW
執行的操作:
     位元組操作:(AL)-((DI)),(DI)<-(DI)+-1
     字操作:   (AL)-((DI)),(DI)<-(DI)+-2
該指令把AL(或AX)的內容與由(DI)指定的在附加段中的一個位元組(或字)進行比較,並不儲存結果,只根據結果置條件碼.指令的其他特性和MOVS的規定相同.

五、控制轉移指令
1.無條件轉移指令
.JMP(jmp)   跳轉指令
1)段內直接短轉移
格式:JMP   SHORT OPR
執行的操作:(IP)<-(IP)+8位位移量
2)段內直接近轉移
格式:JMP   NEAR PTR OPR
執行的操作:(IP)<-(IP)+16位位移量
3)段內間接轉移
格式:JMP   WORD PTR OPR
執行的操作:(IP)<-(EA)
4)段間直接(遠)轉移
格式:JMP   FAR PTR OPR
執行的操作:(IP)<-OPR的段內偏移地址
            (CS)<-OPR所在段的段地址
5)段間間接轉移
格式:JMP   DWORD PTR OPR
執行的操作:(IP)<-(EA)
            (CS)<-(EA+2)
2.條件轉移指令
1)根據單個條件標誌的設定情況轉移
.JZ(或JE)(Jump if zero,or equal)   結果為零(或相等)則轉移
格式:JE(或JZ)   OPR
測試條件:ZF=1
.JNZ(或JNE)(Jump if not zero,or not equal) 結果不為零(或不相等)則轉移
格式:JNZ(或JNE)   OPR
測試條件:ZF=0
.JS(Jump if sign)   結果為負則轉移
格式:   JS   OPR
測試條件:SF=1
.JNS(Jump if not sign)   結果為正則轉移
格式:JNS   OPR
測試條件:SF=0
.JO(Jump if overflow)   溢位則轉移
格式:    JO   OPR
測試條件:OF=1
.JNO(Jump if not overflow)   不溢位則轉移
格式:    JNO OPR
測試條件:OF=0
.JP(或JPE)(Jump if parity,or parity even) 奇偶位為1則轉移
格式:    JP   OPR
測試條件:PF=1
.JNP(或JPO)(Jump if not parity,or parity odd) 奇偶位為0則轉移
格式:    JNP(或JPO)   OPR
測試條件:PF=0
.JB(或JNAE,JC)(Jump if below,or not above or equal,or carry) 低於,或者不高於或等於,或進位位為1則轉移
格式:JB(或JNAE,JC)   OPR
測試條件:CF=1
.JNB(或JAE,JNC)(Jump if not below,or above or equal,or not carry) 不低於,或者高於或者等於,或進位位為0則轉移
格式:JNB(或JAE,JNC)   OPR
測試條件:CF=0
2)比較兩個無符號數,並根據比較的結果轉移
.JB(或JNAE,JC)
格式:同上
.JNB(或JAE,JNC)
格式:同上
.JBE(或JNA)(Jump if below or equal,or not above) 低於或等於,或不高於則轉移
格式:JBE(或JNA)   OPR
測試條件:CFVZF=1
.JNBE(或JA)(Jump if not below or equal,or above) 不低於或等於,或者高於則轉移
格式:JNBE(或JA)   OPR
測試條件:CFVZF=0
3)比較兩個帶符號數,並根據比較的結果轉移
.JL(或LNGE)(Jump if less,or not greater or equal) 小於,或者不大於或者等於則轉移
格式:JL(或JNGE)   OPR
測試條件:SFVOF=1
.JNL(或JGE)(Jump if not less,or greater or equal)不小於,或者大於或者等於則轉移
格式:JNL(或JGE)   OPR
測試條件:SFVOF=0
.JLE(或JNG)(Jump if less or equal,or not greater) 小於或等於,或者不大於則轉移
格式:JLE(或JNG)   OPR
測試條件:(SFVOF)VZF=1
.JNLE(或JG)(Jump if not less or equal,or greater) 不小於或等於,或者大於則轉移
格式:JNLE(或JG)   OPR
測試條件:(SFVOF)VZF=0
4)測試CX的值為0則轉移指令
.JCXZ(Jump if CX register is zero)   CX暫存器的內容為零則轉移
格式:JCXZ   OPR
測試條件:(CX)=0
注:條件轉移全為8位短跳!

3.迴圈指令
.LOOP 迴圈指令
格式: LOOP   OPR
測試條件:(CX)<>0
.LOOPZ/LOOPE 當為零或相等時迴圈指令
格式: LOOPZ(或LOOPE)   OPR
測試條件:(CX)<>0且ZF=1
.LOOPNZ/LOOPNE 當不為零或不相等時迴圈指令
格式: LOOPNZ(或LOOPNE)   OPR
測試條件:(CX)<>0且ZF=0
這三條指令的步驟是:
1)(CX)<-(CX)-1
2)檢查是否滿足測試條件,如滿足則(IP)<-(IP)+D8的符號擴充.

4.子程式
.CALL呼叫指令
.RET返回指令
5.中斷
.INT指令
格式:     INT   TYPE
或        INT
執行的操作:(SP)<-(SP)-2
            ((SP)+1,(SP))<-(PSW)
            (SP)<-(SP)-2
            ((SP)+1,(SP))<-(CS)
            (SP)<-(SP)-2
            ((SP)+1,(SP))<-(IP)
            (IP)<-(TYPE*4)
            (CS)<-(TYPE*4+2)
.INTO   若溢位則中斷
執行的操作:若OF=1則:
            (SP)<-(SP)-2
            ((SP)+1,(SP))<-(PSW)
            (SP)<-(SP)-2
            ((SP)+1,(SP))<-(CS)
            (SP)<-(SP)-2
            ((SP)+1,(SP))<-(IP)
            (IP)<-(10H)
            (CS)<-(12H)
.IRET     從中斷返回指令
格式:      IRET
執行的操作:(IP)<-((SP)+1,(SP))
            (SP)<-(SP)+2
            (CS)<-((SP)+1,(SP))
            (SP)<-(SP)+2
            (PSW)<-((SP)+1,(SP))
            (SP)<-(SP)+2

六、處理機控制指令
1.標誌處理指令
.CLC進位位置0指令(Clear carry)CF<-0
.CMC進位位求反指令(Complement carry)CF<-CF
.STC進位位置1指令(Set carry)CF<-1
.CLD方向標誌置0指令(Clear direction)DF<-0
.STD方向標誌置1指令(Set direction)DF<-1
.CLI中斷標誌置0指令(Clear interrupt)IF<-0
.STI中斷標誌置1指令(Set interrupt)IF<-0
2.其他處理機控制指令
NOP(No Opreation)    無操作
HLT(Halt)            停機
WAIT(Wait)           等待
ESC(Escape)          換碼
LOCK(Lock)           封鎖
這些指令可以控制處理機狀態.這們都不影響條件碼.
.NOP 無操作指令
     該指令不執行任何操作,其機器碼佔有一個位元組,在除錯程式時往往用這條指令佔有一定的儲存單元,以便在正式執行時用其他指令取代.
.HLT停機指令
     該指令可使機器暫停工作,使處理機處於停機狀態以便等待一次外部中斷到來,中斷結束後可繼續執行下面的程式.
.WAIT等待指令
     該指令使處理機處於空轉狀態,它也可以用來等待外部中斷的發生,但中斷結束後仍返回WAIT指令繼續德行.
.ESC換碼指令
    格式ESC   mem
其中mem指出一個儲存單元,ESC指令把該儲存單元的內容送到資料匯流排去.當然ESC指令不允許使用立即數和暫存器定址方式.這條指令在使用協處理機 (Coprocessor)執行某些操作時,可從儲存器指得指令或運算元.協處理機(如8087)則是為了提高速度而可以選配的硬體.
.LOCK封鎖指令
     該指令是一種字首,它可與其他指令聯合,用來維持匯流排的鎖存訊號直到與其聯合的指令執行完為止.當CPU與其他處理機協同工作時,該指令可避免破壞有用資訊.