寄存器 & 匯編指令


概述:寄存器 & 匯編之間的聯系

寄存器 是CPU內部用來存放數據的一些小型存儲區域,用來暫時存放參與運算的數據和運算結果。

匯編指令 是匯編語言中使用的操作符合助記符,還包括一些偽指令。

匯編指令 借助 寄存器和存儲器完成數據的傳輸。

一、寄存器

寄存器為了完成數據的

        清除、接收、存儲、輸出、移位

將寄存器分為以下5種:

1、通用寄存器

16位寄存器: 兼容8位寄存器: 含義
AX AH、AL 累加器
BX BH、BL 基址寄存器
CX CH、CL 計數寄存器
DX DH、DL 數據寄存器

2、指針和編址寄存器

存放的內容是某一段內存地址的偏移量,用來形成操作數地址,主要在堆棧操作和編址運算中使用。

寄存器: 含義
BP( Base Pointer regilter) 基址指針寄存器:存放現行堆棧中一個數據區的基址的偏移量
SP( Stack Pointer Register) 堆棧指針寄存器:現行堆棧段的段內地址偏移量
SI( Source Index register) 源變址寄存器
DI( Destination Index Register) 目的變址寄存器
聯合使用寄存器: 含義
SS:BP 在間接尋址中使用,操作數在堆棧段中,由SS段寄存器與BP組合形成操作數地址
SS:SP PUSH和POP指令從SP寄存器得到現行堆棧段的段內地址偏移量
DS:SI,DS:DI 為訪問現行數據段提供段內地址偏移.在串指令中,其中源操作數的偏移量存放在SⅠ中,目的操作數的偏移量存放在DI中,SI和DI的作用不能互換,否則傳送地址相反。

3、段寄存器

why?

8086/8088CPU可直接尋址1MB的存儲器空間,直接尋址需要20位地址碼,

而所有內部寄存器都是16位的,只能直接尋址6KB,因此采用分段技術來解決。

將1MB的存儲空間分成若干邏輯段,每段最長64KB,這些邏輯段在整個存儲空間中可浮動。

what?

寄存器: 含義
CS 段寄存器:存放現行代碼段的基地址
DS 數據段寄存器:存放操作的數據
SS 堆棧段寄存器:存放現行堆棧的基地址
ES 附加段寄存器:存放操作的數據

4、指令指針寄存器 IP

what?

指針寄存器IP,用來存放將要執行的下一條指令在現行代碼段中的偏移地址

how?

運行中,它由BIU自動修改,使IP始終指向下一條將要執行的指令的地址,

用來 控制指令序列的執行流程.

IP指針的修改: 通過某些指令修改,

如 int 0x80中斷指令、CALL xxx調用子程序指令【自動調整IP內容,

將IP中下一條將要執行的指令偏移量入棧,中斷或子程序執行完后,

從堆棧中彈出IP,是主程序繼續運行。 】

如 JMP XXX 跳轉指令【將新的跳轉地址覆蓋當前IP,完成程序的轉移】

5、標志(程序狀態)寄存器 FR

CF、PF、AF、ZF、SF和OF:寄存程序運行的狀態信息,這些標志往往用作后續指令判斷的依據

IF、DF和TF:用於控制CPU的操作,人為設定

二、匯編指令

數據傳輸

在存儲器和寄存器、寄存器和輸入輸出端口之間傳送數據

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、輸入輸出端口傳送指令

輸入輸出端口由立即方式指定時, 其范圍是 0-255; 由寄存器 DX 指定時,
其范圍是 0-65535.

IN I/O端口輸入. ( 語法: IN 累加器, {端口號│DX} )

OUT I/O端口輸出. ( 語法: OUT {端口號│DX},累加器 )

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位標志出棧.

算數運算

ADD 加法.

ADC 帶進位加法.

INC 加 1.

AAA 加法的ASCII碼調整.

DAA 加法的十進制調整.

SUB 減法.

SBB 帶借位減法.

DEC 減 1.

NEG 取補

CMP 比較.(兩操作數作減法,僅修改標志位,不回送結果).

AAS 減法的ASCII碼調整.

DAS 減法的十進制調整.

MUL 無符號乘法.

IMUL 整數乘法.

以上兩條,結果回送AH和AL(字節運算),或DX和AX(字運算).

AAM 乘法的ASCII碼調整.

結果回送:商回送AL,余數回送AH, (字節運算);或 商回送AX,余數回送DX, (字運算).
DIV 無符號除法.
IDIV 整數除法.

AAD 除法的ASCII碼調整.

CBW 字節轉換為字. (把AL中字節的符號擴展到AH中去)

CWD 字轉換為雙字. (把AX中的字的符號擴展到DX中去)

CWDE 字轉換為雙字. (把AX中的字符號擴展到EAX中去)

CDQ 雙字擴展. (把EAX中的字的符號擴展到EDX中去)

邏輯運算

移位次數可達255次:
移位一次時, 可直接用操作碼. 如 SHL AX,1.
移位>1次時, 則由寄存器CL給出移位次數. 如 MOV CL,04 SHL AX,CL

AND 與運算.

or 或運算.

XOR 異或運算.

NOT 取反.

TEST 測試.(兩操作數作與運算,僅修改標志位,不回送結果).

SHL 邏輯左移.

SAL 算術左移.(=SHL)

SHR 邏輯右移.( 每位右移, 低位進 CF, 高位補 0)

SAR 算術右移.(每位右移, 低位進 CF, 高位不變)

ROL 循環左移.

ROR 循環右移.

RCL 通過進位的循環左移.

RCR 通過進位的循環右移.

串指令

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時重復

程序轉移

無條件轉移指令

JMP 無條件轉移指令

CALL 過程調用

RET/RETF過程返回

條件轉移指令

( 當且僅當(SF XOR OF)=1時,OP1<OP2 )

測試無符號整數運算的結果(標志C和Z):
JA/JNBE 大於轉移

JAE/JNB 大於或等於轉移.

JB/JNAE 小於轉移.

JBE/JNA 小於或等於轉移.

測試帶符號整數運算的結果(標志S,O和Z)
JG/JNLE 大於轉移.

JGE/JNL 大於或等於轉移.

JL/JNGE 小於轉移.

JLE/JNG 小於或等於轉移.

JE/JZ 等於轉移.
JNE/JNZ 不等於時轉移.
JC 有進位時轉移.
JNC 無進位時轉移.
JNO 不溢出時轉移.
JNP/JPO 奇偶性為奇數時轉移.
JNS 符號位為 "0" 時轉移.
JO 溢出轉移.
JP/JPE 奇偶性為偶數時轉移.
JS 符號位為 "1" 時轉移.

循環控制指令(短轉移)

LOOP CX不為零時循環.

LOOPE/LOOPZ CX不為零且標志Z=1時循環.

LOOPNE/LOOPNZ CX不為零且標志Z=0時循環.

JCXZ CX為零時轉移.

JECXZ ECX為零時轉移.

中斷指令

INT 中斷指令

INTO 溢出中斷

IRET 中斷返回

偽指令

DB定義字節(1字節)

DW 定義字(2字節).

DD定義雙字(4字節)

PROC 定義過程.

ENDP 過程結束.

SEGMENT 定義段.

ASSUME 建立段寄存器尋址.

ENDS 段結束.

END 程序結束.

控制指令

標志處理指令 CLC(進位位置0指令)

CMC(進位位求反指令)

CLC(進位位置為0指令)

STC(進位位置為1指令)

CLD(方向標志位置0指令)

STD(方向標志位置1指令)

CLI(中斷標志置0指令)

STI(中斷標志置1指令)

NOP(無操作)

HLT(停機)

WAIT(等待)

ESC(換碼)

LOCK(封鎖)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM