標志寄存器的概念
首先說一下標志寄存器的概念。在8086cpu中標志寄存器都是16位的,而其中存儲的信息被稱為程序狀態字(一段包含系統狀態的內存或者是硬件區域)。標志寄存器既然是寄存器,那么它也是用來存儲信息的,只是它存儲信息的方式與其他的寄存器不同而已。其他的寄存器是一個寄存器包含一個信息,而標志寄存器則可以包含多個信息。而標志寄存器之所以可以存儲多個信息,是因為它的存儲方式。在標志寄存器中,信息是被存儲在位中的。標志寄存器中的每一個位都可以代表特定的信息。
這是我在網上找的一個標志寄存器的示意圖。通過這張圖片我們可以知道在標志寄存器中,哪些是用到的,哪些是沒用到的。我就不在贅述了。接下來我們看一下這些位的具體含義。
CF(carry flag):進位標志位。這個位是在進行無符號數運算的時候用到的。一般情況下,這個位記錄了進行無符號運算的時候,運算結果的最高有效位向更高位的進位值,或從更高位的借位值。注意的是,這里的進位與借位,都是相對于二進制而言的。下面我們再找一張圖來加深下理解。
PF(parity flag):奇偶標志位。這個位的判斷需要我們將結果轉為二進制來看,如果結果的低8位中有偶數個1,就將PF的值置1;如果是奇數個1,就置0。要注意的是一定是結果的低8位。
PF,奇偶標志位,flag的第2位記錄相關指令執行后,其結果所有bit位中1的個數是否為偶數,若為偶數,則PF=1;若為奇數,PF=0.
執行
mov al,00000000b
add al,00000111b
mov al,00000000b
add al,00000011b
驗證:
AF(auxiliary flag):輔助進位標志位。這個位用的不多,所以書上也沒有講,我就簡單的查了一下資料。這個位表示加減法做到一半時有沒有形成進位/借位,如果有則AF=1。這么說誰都聽不懂,所以我們舉個例子來說下。例如 MOV AL,00001110 MOV BL,00001000 ADD AL,BL 最后結果為AL=00010110這就是低四位向高四位進位。反之在減法中第三位不夠減向第四位借位(注意數位是從第0位開始數的)叫低四位向高四位借位!像前面的AL中前四位為高四位,后四位為低四位。例如,當兩個字節相加時,如果從低4位向高4位有進位時,則AF=1。
ZF(zero flag):零標志位。這個位就很簡單了,判斷結果是不是0。如果結果為0,就置1;不為0,就置0。
執行
mov ax,1
sub ax,1
mov ax,2
sub ax,1
可以看到 當計算ax結果為0時,ZF是ZR=1;結果為1(不為0)時,ZF是NZ=0.
SF(sign flag):符號標志位。既然是符號標志位,就是對有符號數據來說的。如果結果為負,就置1;結果為正,就置0。
SF,符號標志位,flag的第7位,記錄相關指令執行后,其結果是否為負,若為負,則SF=1;若為非負,SF=0.
執行:
mov al,10000001b
add al,1
mov al,10000000b
add al,01111111b
驗證:
當SF=1即為NG,表示:若指令進行有符號數運算,則結果為負
當SF=0即為PL,表示: 若指令進行有符號數運算,則結果為非負
TF(timer overblow flag):定時器溢出標志。這個位主要是用來在debug中進行-t指令時使用的。當cpu在執行完一條指令后,如果檢測到TF位的值為1,則產生單步中斷,引發中斷過程。通過這個位,我們就可以在debug中對程序進行單步跟蹤。
IF(interrupt flag):中斷允許標志位。當IF=1時,cpu在執行完當前指令后響應中斷,引發中斷過程;當IF=0時,則不響應可屏蔽中斷。
DF(direction flag):方向標志位。在串處理指令中,控制每次操作后,si(指向原始偏移地址)、di(指向目標偏移地址)的增減。當DF=0時,每次操作后,si、di遞增;DF=1時,每次操作后,si、di遞減。我們可以使用cld指令將DF的值置為0,使用std指令將DF的值置為1。DF需要與rep、movsb等指令配合使用。
OF(overflow flag):溢出標志位。這個位是用來判斷有沒有溢出的。注意溢出這個概念只對于有符號數據而言,就如同進位只對于無符號數據而言。當OF=0時,說明沒有溢出;當OF=1時,說明溢出了。
OF,溢出標志位,flag的第11位,超出機器所能表示的范圍稱為溢出若發生了溢出OF=1,若沒有則OF=0
比如對于8位有符號數據,機器能表示范圍是 -128~127;對于16位有符號數據,范圍是 -32768~32767
執行:
mov al,64
add al,64
mov al,63
add al,64
驗證:
下面有幾個串傳送指令
格式:movsb
功能:執行movsb指令相當于進行下面幾步操作。
1) ((es)*16+(di)) = ((ds)*16+(si))
2) 如果df=0 則 (si)=(si)+1 (di)=(di)+1
如果df=1則: (si)=(si)-1 (di)=(di)-1
當然也可以傳送一個字
格式:movsw
功能:將ds:si指向的內存單元中的字送入es:di中,然后根據標志寄存器df位的值,將si和di遞增2或遞減2.
movsb和movsw進行的是串傳送操作中的一個步驟,一般來說,movsb和movsw都和rep配合使用,格式如下:
rep movsb
rep功能:根據cx的值,重復執行后面的串傳送指令。由于每執行一次movsb指令si和di都會遞增或遞減指向后一個單元或前一個單元,則rep movsb就可以循環實現(cx)個字符的傳送。
8086CPU提供下面兩條指令對df位進行設置。
cld指令: 將標志寄存器的df位置0
std指令: 將標志寄存器的df位置1
1)編程,用串傳送指令,將data段中的第一個字符串復制到它后面的空間中。
data segment
db ‘welcome to masm!’
db 16 dup (0)
data ends
code segment
mov ax,data
mov ds,ax
mov si, 0
mov es,ax
mov di,16
mov cx,16
cld
rep movsb
code ends
end
2)編程,用串傳送指令,將F000段中的最后16個字符復制到data段中。
data segment
db 16 dup (0)
data ends
code segment
mov ax,0f000h
mov ds,ax
mov si, 0ffffh
mov ax,data
mov es,ax
mov di, 15
mov cx, 16
std
rep movsb
code ends
end
非常好我支持^.^
(1) 100%
不好我反對
(0) 0%
相關閱讀:
- [電子說] 學習STM32F103的ADC功能 2023-10-24
- [電子說] 學習STM32F103的DAC功能 2023-10-24
- [電子說] 學習STM32F103的定時器功能 2023-10-24
- [電子說] STM32基礎知識:定時器的PWM輸出功能 2023-10-24
- [電子說] 既然ODR能控制管腳高低電平,為什么還需要BSRR寄存器呢? 2023-10-24
- [電子說] ARM系列-P Channel簡析 2023-10-24
- [控制/MCU] 基于STM32F429芯片的單片機芯片內存映射圖 2023-10-23
- [電子說] ICCV 2023 | 面向視覺-語言導航的實體-標志物對齊自適應預訓練方法 2023-10-23
( 發表人:李倩 )