微控制器特殊功能暫存器,這是微控制器中最核心的地方,也是理解整個微控制器的基礎,學會了這裡,也就相當於明白了暫存器的意義了。
方法/步驟
1、ACC---是累加器,通常用A表示
這是個什麼東西,可不能從名字上理解,它是一個暫存器,而不是一個做加法的東西,為什麼給它這麼一個名字呢?或許是因為在運算器做運算時其中一個數一定是在ACC中的緣故吧。它的名字特殊,身份也特殊,稍後在中篇中我們將學到指令,可以發現,所有的運算類指令都離不開它。自身帶有全零標誌Z,若A=0則Z=1;若A≠0則z=0。該標誌常用作程式分枝轉移的判斷條件。
2、B--一個暫存器
在做乘、除法時放乘數或除數,不做乘除法時,隨你怎麼用。
3、PSW-----程式狀態字。
這是一個很重要的東西,裡面放了CPU工作時的很多狀態,藉此,我們可以瞭解CPU的當前狀態,並作出相應的處理。它的各位功能請看下錶:
CY:進位標誌。
8051中的運算器是一種8位的運算器,我們知道,8位運算器只能表示到0-255,如果做加法的話,兩數相加可能會超過255,這樣最高位就會丟失,造成運算的錯誤,怎麼辦?最高位就進到這裡來。這樣就沒事了。有進、借位,CY=1;無進、借位,CY=0 例:78H+97H(01111000+10010111)
AC:輔助進、借位(高半位元組與低半位元組間的進、借位)。
例:57H+3AH(01010111+00111010)
F0:使用者標誌位
由使用者(程式設計人員)決定什麼時候用,什麼時候不用。
RS1、RS0:工作暫存器組選擇位
通過修改PSW中的RS1、RS0兩位的狀態,就能任選一個工作暫存器區。這個特點提高了MCS-51現場保護和現場恢復的速度。對於提高CPU的工作效率和響應中斷的速度是很有利的。若在一個實際的應用系統中,不需要四組工作暫存器,那麼這個區域中多餘單元可以作為一般的資料緩衝器使用。
0V:溢位標誌位
運算結果按補碼運算理解。有溢位,OV=1;無溢位,OV=0。什麼是溢位我們後面的章節會講到。
P:奇偶校驗位
它用來表示ALU運算結果中二進位制數位“1”的個數的奇偶性。若為奇數,則P=1,否則為0。運算結果有奇數個1,P=1;運算結果有偶數個1,P=0。 例:某運算結果是78H(01111000),顯然1的個數為偶數,所以P=0。
4、DPTR(DPH、DPL)--------資料指標
可以用它來訪問外部資料儲存器中的任一單元,如果不用,也可以作為通用暫存器來用,由我們自已決定如何使用。分成DPL(低8位)和DPH(高8位)兩個暫存器。用來存放16位地址值,以便用間接定址或變址定址的方式對片外資料RAM或程式儲存器作64K位元組範圍內的資料操作。
5、P0、P1、P2、P3--------輸入輸出口(I/O)暫存器
這個我們已經知道,是四個並行輸入/輸出口(I/O)的暫存器。它裡面的內容對應著管腳的輸出。
6、IE-----中斷充許暫存器可按位定址,地址:A8H
EA (IE.7):EA=0時,所有中斷禁止(即不產生中斷);EA=1時,各中斷的產生由個別的允許位決定
- (IE.6):保留
ET2(IE.5):定時2溢位中斷允許(8052用)
ES (IE.4):序列口中斷允許(ES=1允許,ES=0禁止)
ET1(IE.3):定時1中斷允許
EX1(IE.2):外中斷INT1中斷允許
ET0(IE.1):定時器0中斷允許
EX0(IE.0):外部中斷INT0的中斷允
7、IP-----中斷優先順序控制暫存器可按位定址,地址位B8H
- (IP.7):保留
- (IP.6):保留
PT2(IP.5):定時2中斷優先(8052用)
PS (IP.4):序列口中斷優先
PT1(IP.3):定時1中斷優先
PX1(IP.2):外中斷INT1中斷優先
PT0(IP.1):定時器0中斷優先
PX0(IP.0):外部中斷INT0的中斷優先
8、TMOD-----定時器控制暫存器不按位定址,地址89H
GATE :定時操作開關控制位,當GATE=1時,INT0或INT1引腳為高電平,同時TCON中的TR0或TR1控制位為1時,計時/計數器0或1才開始工作。若GATE=0,則只要將TR0或TR1控制位設為1,計時/計數器0或1就開始工作。
C/T :定時器或計數器功能的選擇位。C/T=1為計數器,通過外部引腳T0或T1輸入計數脈衝。C/T=0時為定時器,由內部系統時鐘提供計時工作脈衝。
M1 、M0:T0、T1工作模式選擇位
9、TCON-----定時器控制暫存器
可按位定址,地址位88H
TF1:定時器T1溢位標誌,可由程式查詢和清零,TF1也是中斷請求源,當CPU響應T1中斷時由硬體清零。
TF0:定時器T0溢位標誌,可由程式查詢和清零,TF0也是中斷請求源,當CPU響應T0中斷時由硬體清零。
TR1:T1充許計數控制位,為1時充許T1計數。
TR0:T0充許計數控制位,為1時充許T0計數。
IE1:外部中斷1請示源(INT1,P3.3)標誌。IE1=1,外部中斷1正在向CPU請求中斷,當CPU響應該中斷時由硬體清“0”IE1(邊沿觸發方式)。
IT1:外部中斷源1觸發方式控制位。IT1=0,外部中斷1程控為電平觸發方式,當INT1(P3.3)輸入低電平時,置位IE1。
IE0:外部中斷0請示源(INT0,P3.2)標誌。IE0=1,外部中斷1正在向CPU請求中斷,當CPU響應該中斷時由硬體清“0”IE0(邊沿觸發方式)。
IT0:外部中斷源0觸發方式控制位。IT0=0,外部中斷1程控為電平觸發方式,當INT0(P3.2)輸入低電平時,置位IE0。
10、SCON----序列通訊控制暫存器
它是一個可定址的專用暫存器,用於序列資料的通訊控制,單元地址是98H,其結構格式如下:
(1)SM0、SM1:序列口工作方式控制位。 SM0,SM1 工作方式 00 方式0-波特率由振盪器頻率所定:振盪器頻率/12 01 方式1-波特率由定時器T1或T2的溢位率和SMOD所定:2SMOD ×(T1溢位率)/32 10 方式2-波特率由振盪器頻率和SMOD所定:2SMOD ×振盪器頻率/64 11 方式3-波特率由定時器T1或T2的溢位率和SMOD所定:2SMOD ×(T1溢位率)/32 (2)SM2:多機通訊控制位。< br> 多機通訊是工作於方式2和方式3,SM2位主要用於方式2和方式3。接收狀態,當序列口工作於方式2或3,以及SM2=1時,只有當接收到第9位資料(RB8)為1時,才把接收到的前8位資料送入SBUF,且置位RI發出中斷申請,否則會將接受到的資料放棄。當SM2=0時,就不管第位資料是0還是1,都難得資料送入SBUF,併發出中斷申請。工作於方式0時,SM2必須為0。 (3)REN:允許接收位。< br> REN用於控制資料接收的允許和禁止,REN=1時,允許接收,REN=0時,禁止接收。 (4)TB8:傳送接收資料位8。< br> 在方式2和方式3中,TB8是要傳送的——即第9位資料位。在多機通訊中同樣亦要傳輸這一位,並且它代表傳輸的地址還是資料,TB8=0為資料,TB8=1時為地址。 (5)RB8:接收資料位8。在方式2和方式3中,RB8存放接收到的第9位資料,用以識別接收到的資料特徵。 (6)TI:傳送中斷標誌位。可定址標誌位。方式0時,傳送完第8位資料後,由硬體置位,其它方式下,在傳送或停止位之前由硬體置位,因此,TI=1表示幀傳送結束,TI可由軟體清“0”。 (7)RI:接收中斷標誌位。可定址標誌位。接收完第8位資料後,該位由硬體置位,在其他工作方式下,該位由硬體置位,RI=1表示幀接收完成。
11、PCON-----電源管理暫存器
PCON主要是為CHMOS型微控制器的電源控制而設定的專用暫存器,單元地址是87H,其結構格式如下:
在CHMOS型微控制器中,除SMOD位外,其他位均為虛設的,SMOD是序列口波特率倍增位,當SMOD=1時,序列口波特率加倍。系統復位預設為SMOD=0。
12、T2CON-----T2狀態控制暫存器
TF2:T2溢位中斷標誌。TF2必須由使用者程式清“0”。當T2作為串列埠波特率發生器時,TF2不會被置“1”。
EXF2:定時器T2外部中斷標誌。EXEN2為1時,當T2EX(P1.1)發生負跳變時置1中斷標誌DXF2,EXF2必須由使用者程式清“0”。
TCLK:序列介面的傳送時鐘選擇標誌。TCLK=1時,T2工作于波特率發生器方式。
RCLK:序列介面的接收時鐘選擇標誌位。RCLK=1時,T2工作于波特率發生器方式。
EXEN2:T2的外部中斷充許標誌。
C/T2:外部計數器/定時器選擇位。C/T2=1時,T2為外部事件計數器,計數脈衝來自T2(P1.0);C/T2=0時,T2為定時器,振盪脈衝的十二分頻訊號作為計數訊號。
TR2:T2計數/定時控制位。TR1為1時充許計數,為0時禁止計數。
CP/RL2:捕捉和常數自動再裝入方式選擇位。為1時工作於捕捉方式,為0時T2工作於常數自動再裝入方式。當TCLK或RCLK為1時,CP/RL2被忽略,T2總是工作於常數自動再裝入方式。