標誌暫存器是乙個很特殊的暫存器,所以有必要分單張來講講一下。
標誌暫存器在32位作業系統中大小是32-bit的,也就是說,它可以存32個標誌。實際上標誌暫存器並沒有完全被使用,如上圖,我們可以見到有一些地方是沒有用到的,大多數情況下,我們只需學習運算結果標誌位就可以了,其他的用到的地方不多,下面我們來了解一下各標誌位的作用。
1、進製標誌cf(carry flag)
進製標誌cf主要用來反映運算是否產生進製或借位。如果運算結果的最高位產生了乙個進製或借位,那麼,其值為1,否則其值為0。
使用該標誌位的情況有:多字(位元組)數的加減運算,無符號數的大小比較運算,移位操作,字(位元組)之間移位,專門改變cf值的指令等。
2、奇偶標誌pf(parity flag)
奇偶標誌pf用於反映運算結果中「1」的個數的奇偶性。如果「1」的個數為偶數,則pf的值為1,否則其值為0。
利用pf可進行奇偶校驗檢查,或產生奇偶校驗位。在資料傳送過程中,為了提供傳送的可靠性,如果採用奇偶校驗的方法,就可使用該標誌位。
3、輔助進製標誌af(auxiliary carry flag)
在發生下列情況時,輔助進製標誌af的值被置為1,否則其值為0:
對以上6個運算結果標誌位,在一般程式設計情況下,標誌位cf、zf、sf和of的使用頻率較高,而標誌位pf和af的使用頻率較低。
4、零標誌zf(zero flag)
零標誌zf用來反映運算結果是否為0。如果運算結果為0,則其值為1,否則其值為0。在判斷運算結果是否為0時,可使用此標誌位。
5、符號標誌sf(sign flag)
符號標誌sf用來反映運算結果的符號位,它與運算結果的最高位相同。在微機系統中,有符號數採用補碼表示法,所以,sf也就反映運算結果的正負號。運算結果為正數時,sf的值為0,否則其值為1。
6、溢位標誌of(overflow flag)
溢位標誌of用於反映有符號數加減運算所得結果是否溢位。如果運算結果超過當前運算位數所能表示的範圍,則稱為溢位,of的值被置為1,否則,of的值被清為0。
「溢位」和「進製」是兩個不同含義的概念,不要混淆。如果不太清楚的話,請查閱《計算機組成原理》課程中的有關章節。
狀態控制標誌位是用來控制cpu操作的,它們要通過專門的指令才能使之發生改變。
1、追蹤標誌tf(trap flag)
當追蹤標誌tf被置為1時,cpu進入單步執行方式,即每執行一條指令,產生乙個單步中斷請求。這種方式主要用於程式的除錯。
指令系統中沒有專門的指令來改變標誌位tf的值,但程式設計師可用其它辦法來改變其值。
2、中斷允許標誌if(interrupt-enable flag)
中斷允許標誌if是用來決定cpu是否響應cpu外部的可遮蔽中斷發出的中斷請求。但不管該標誌為何值,cpu都必須響應cpu外部的不可遮蔽中斷所發出的中斷請求,以及cpu內部產生的中斷請求。具體規定如下:
cpu的指令系統中也有專門的指令來改變標誌位if的值。
3、方向標誌df(direction flag)
方向標誌df用來決定在串操作指令執行時有關指標暫存器發生調整的方向。在微機的指令系統中,還提供了專門的指令來改變標誌位df的值。
1、i/o特權標誌iopl(i/o privilege level)
i/o特權標誌用兩位二進位制位來表示,也稱為i/o特權級字段。該欄位指定了要求執行i/o指令的特權級。如果當前的特權級別在數值上小於等於iopl的值,那麼,該i/o指令可執行,否則將發生乙個保護異常。
2、巢狀任務標誌nt(nested task)
巢狀任務標誌nt用來控制中斷返回指令iret的執行。具體規定如下:
3、重啟動標誌rf(restart flag)
重啟動標誌rf用來控制是否接受除錯故障。規定:rf=0時,表示「接受」除錯故障,否則拒絕之。在成功執行完一條指令後,處理機把rf置為0,當接受到乙個非除錯故障時,處理機就把它置為1。
4、虛擬8086方式標誌vm(virtual 8086 mode)
如果該標誌的值為1,則表示處理機處於虛擬的8086方式下的工作狀態,否則,處理機處於一般保護方式下的工作狀態。
彙編 二 暫存器的介紹
what?什麼是暫存器 對於乙個程式設計師來說.cpu中主要的部件是暫存器,暫存器是cpu中程式設計師可以用指令讀寫的部件,程式設計師通過改變各種暫存器中的內容來實現對cpu的控制 在8086cpu中一共有14個暫存器,每個暫存器有乙個名稱,這些暫存器是 ax,bx,cx,dx,si,di,sp,b...
彙編基礎 暫存器英文全稱
ah al ax accumulator 累加暫存器 bh bl bx base 基址暫存器 ch cl cx count 計數暫存器 dh dl dx data 資料暫存器 sp stack pointer 堆疊指標暫存器 bp base pointer 基址指標暫存器 si source ind...
彙編基礎之暫存器及彙編指令
最近在學習協程方面的知識,在協程的一種實現方式中有一種是用彙編實現的,所以這裡再把彙編知識複習一下。暫存器按照其用途可分為以下4類 資料暫存器包括 個16位的暫存器 ax,bx,cx,dx 或者8個8位的暫存器 ah,al,bh,bl,ch,cl,dh,dl 這些暫存器都是用來暫時存放運算元,運算結...