您好,歡迎來電子發燒友網! ,新用戶?[免費注冊]

您的位置:電子發燒友網 > 電子百科 > 主機配件 > cpu >

標志寄存器的概念

2019年07月22日 10:00 lq 作者: 用戶評論(0

  首先說一下標志寄存器的概念。在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中對程序進行單步跟蹤。

  (inte含羞草rrupt flag):中斷允許標志位。當IF=1時,cpu在執行完當前指令后響應中斷,引發中斷過程;當IF=0時,則不響應可屏蔽中斷。

  DF(direcon flag):方向標志位。在串處理指令中,控制每次操作后,si(指向原始偏移地址)、di(指向目標偏移地址)的增減。當DF=0時,每次操作后,si、di遞增;DF=1時,每次操作后,si、di遞減。我們可以使用cld指令將DF的值置為0,使用std指令將DF的值置為1。DF需要與rep、movsb等指令配合使用。

  OF(ovelow 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

非常好我支持^.^

(0) 0%

不好我反對

(0) 0%

( 發表人:李倩 )

      發表評論

      用戶評論
      評價:好評中評差評

      發表評論,獲取積分! 請遵守相關規定!

      ?