0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

關(guān)于51單片機寄存器的功能

貿(mào)澤電子設(shè)計圈 ? 來源:lq ? 2019-05-15 10:22 ? 次閱讀

21個特殊功能寄存器(52系列是26個)不連續(xù)地分布在128個字節(jié)的SFR存儲空間中,地址空間為80H-FFH。在這片SFR空間中,包含有128個位地址空間,地址也是80H-FFH,但只有83個有效位地址,可對11個特殊功能寄存器的某些位做尋址操作(這里介紹一個技巧:其地址能被8整除的都可以位尋址)。

51單片機內(nèi)部有一個CPU用來運算、控制,有四個并行I/O口,分別是P0、P1、P2、P3。有ROM用來存放程序,有RAM用來存放中間結(jié)果;此外還有定時/計數(shù)器,串行I/O口,中斷系統(tǒng),以及一個內(nèi)部的時鐘電路。在單片機中有一些獨立的存儲單元是用來控制這些器件的,被稱之為特殊功能寄存器(SFR)。這樣的特殊功能寄存器51單片機共有21個,并且都是可尋址的列表如下(其中帶*號的為52系列所增加的特殊功能寄存器):

分別說明如下:

1、ACC---是累加器,通常用A表示

它是一個寄存器,而不是一個做加法的東西。為什么給它這么一個名字呢?或許是因為在運算器做運算時其中一個數(shù)一定是在ACC中的緣故吧。它的名字特殊,身份也特殊。稍后在中篇中我們將學到指令,可以發(fā)現(xiàn)所有的運算類指令都離不開它。自身帶有全零標志Z,若A=0則Z=1;若A≠0則z=0。該標志常用作程序分枝轉(zhuǎn)移的判斷條件。

2、B---寄存器

在做乘、除法時放乘數(shù)或除數(shù),不做乘除法時,隨你怎么用。

3、PSW---程序狀態(tài)字

這是一個很重要的東西,里面放了CPU工作時的很多狀態(tài)。借此,我們可以了解CPU的當前狀態(tài),并作出相應(yīng)的處理。它的各位功能請看下表:

下面我們逐一介紹各位的用途

CY:進位標志

8051中的運算器是一種8位的運算器,我們知道,8位運算器只能表示到0-255。如果做加法的話,兩數(shù)相加可能會超過255;這樣最高位就會丟失,造成運算的錯誤,怎么辦?最高位就進到這里來。這樣就沒事了。有進、借位,CY=1;無進、借位,CY=0

例:78H+97H(01111000+10010111)

AC:輔助進、借位(高半字節(jié)與低半字節(jié)間的進、借位)

例:57H+3AH(01010111+00111010)

F0:用戶標志位

由用戶(編程人員)決定什么時候用,什么時候不用。

RS1、RS0:工作寄存器組選擇位

通過修改PSW中的RS1、RS0兩位的狀態(tài),就能任選一個工作寄存器區(qū)。這個特點提高了MCS-51現(xiàn)場保護和現(xiàn)場恢復(fù)的速度。對于提高CPU的工作效率和響應(yīng)中斷的速度是很有利的。若在一個實際的應(yīng)用系統(tǒng)中,不需要四組工作寄存器,那么這個區(qū)域中多余單元可以作為一般的數(shù)據(jù)緩沖器使用。

OV:溢出標志位

運算結(jié)果按補碼運算理解。有溢出,OV=1;無溢出,OV=0。

P:奇偶校驗位

它用來表示ALU運算結(jié)果中二進制數(shù)位“1”的個數(shù)的奇偶性。若為奇數(shù),則P=1,否則為0。運算結(jié)果有奇數(shù)個1,P=1;運算結(jié)果有偶數(shù)個1,P=0。

例:某運算結(jié)果是78H(01111000),顯然1的個數(shù)為偶數(shù),所以P=0。

4、DPTR(DPH、DPL)--------數(shù)據(jù)指針

可以用它來訪問外部數(shù)據(jù)存儲器中的任一單元,如果不用,也可以作為通用寄存器來用,由我們自已決定如何使用。分成DPL(低8位)和DPH(高8位)兩個寄存器。用來存放16位地址值,以間接尋址或變址尋址的方式對片外數(shù)據(jù)RAM或程序存儲器執(zhí)行64K字節(jié)范圍內(nèi)的數(shù)據(jù)操作。

5、P0、P1、P2、P3---輸入輸出口(I/O)寄存器

這個我們已經(jīng)知道,是四個并行輸入/輸出口(I/O)的寄存器。它里面的內(nèi)容對應(yīng)著管腳的輸出。

6、IE---中斷充許寄存器

可按位尋址,地址:A8H

EA (IE.7):EA=0時,所有中斷禁止(即不產(chǎn)生中斷);EA=1時,各中斷的產(chǎn)生由個別的允許位決定

- (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---中斷優(yōu)先級控制寄存器

可按位尋址,地址位B8H

- (IP.7):保留

- (IP.6):保留

PT2(IP.5):定時2中斷優(yōu)先(8052用)

PS (IP.4):串行口中斷優(yōu)先

PT1(IP.3):定時1中斷優(yōu)先

PX1(IP.2):外中斷INT1中斷優(yōu)先

PT0(IP.1):定時器0中斷優(yōu)先

PX0(IP.0):外部中斷INT0的中斷優(yōu)先

8、TMOD---定時器控制寄存器

不按位尋址,地址89H

GATE :定時操作開關(guān)控制位,當GATE=1時,INT0或INT1引腳為高電平,同時TCON中的TR0或TR1控制位為1時,計時/計數(shù)器0或1才開始工作。若GATE=0,則只要將TR0或TR1控制位設(shè)為1,計時/計數(shù)器0或1就開始工作。

C/T :定時器或計數(shù)器功能的選擇位。C/T=1為計數(shù)器,通過外部引腳T0或T1輸入計數(shù)脈沖。C/T=0時為定時器,由內(nèi)部系統(tǒng)時鐘提供計時工作脈沖。

M1、M0:T0、T1工作模式選擇位

9、TCON---定時器控制寄存器

可按位尋址,地址位88H

TF1:定時器T1溢出標志,可由程序查詢和清零,TF1也是中斷請求源,當CPU響應(yīng)T1中斷時由硬件清零。

TF0:定時器T0溢出標志,可由程序查詢和清零,TF0也是中斷請求源,當CPU響應(yīng)T0中斷時由硬件清零。

TR1:T1充許計數(shù)控制位,為1時充許T1計數(shù)。

TR0:T0充許計數(shù)控制位,為1時充許T0計數(shù)。

IE1:外部中斷1請示源(INT1,P3.3)標志。IE1=1,外部中斷1正在向CPU請求中斷,當CPU響應(yīng)該中斷時由硬件清“0”IE1(邊沿觸發(fā)方式)。

IT1:外部中斷源1觸發(fā)方式控制位。IT1=0,外部中斷1程控為電平觸發(fā)方式,當INT1(P3.3)輸入低電平時,置位IE1。

IE0:外部中斷0請示源(INT0,P3.2)標志。IE0=1,外部中斷1正在向CPU請求中斷,當CPU響應(yīng)該中斷時由硬件清“0”IE0(邊沿觸發(fā)方式)。

IT0:外部中斷源0觸發(fā)方式控制位。IT0=0,外部中斷1程控為電平觸發(fā)方式,當INT0(P3.2)輸入低電平時,置位IE0。

10、SCON---串行通信控制寄存器

它是一個可尋址的專用寄存器,用于串行數(shù)據(jù)的通信控制,單元地址是98H,其結(jié)構(gòu)格式如下:

(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:多機通信控制位。

多機通信是工作于方式2和方式3,SM2位主要用于方式2和方式3。接收狀態(tài),當串行口工作于方式2或3,以及SM2=1時,只有當接收到第9位數(shù)據(jù)(RB8)為1時,才把接收到的前8位數(shù)據(jù)送入SBUF,且置位RI發(fā)出中斷申請,否則會將接受到的數(shù)據(jù)放棄。當SM2=0時,不管位數(shù)據(jù)是0還是1,都不能將數(shù)據(jù)送入SBUF,并發(fā)出中斷申請。

工作于方式0時,SM2必須為0。

(3)REN:允許接收位。

REN用于控制數(shù)據(jù)接收的允許和禁止,REN=1時,允許接收,REN=0時,禁止接收。

(4)TB8:發(fā)送接收數(shù)據(jù)位8。

在方式2和方式3中,TB8是要發(fā)送的——即第9位數(shù)據(jù)位。在多機通信中同樣亦要傳輸這一位,并且它代表傳輸?shù)牡刂愤€是數(shù)據(jù),TB8=0為數(shù)據(jù),TB8=1時為地址。

(5)RB8:接收數(shù)據(jù)位8。

在方式2和方式3中,RB8存放接收到的第9位數(shù)據(jù),用以識別接收到的數(shù)據(jù)特征。

(6)TI:發(fā)送中斷標志位。

可尋址標志位。方式0時,發(fā)送完第8位數(shù)據(jù)后,由硬件置位,其它方式下,在發(fā)送或停止位之前由硬件置位,因此,TI=1表示幀發(fā)送結(jié)束,TI可由軟件清“0”。

(7)RI:接收中斷標志位。

可尋址標志位。接收完第8位數(shù)據(jù)后,該位由硬件置位,在其他工作方式下,該位由硬件置位,RI=1表示幀接收完成。

11、PCON---電源管理寄存器

PCON主要是為CHMOS型單片機的電源控制而設(shè)置的專用寄存器,單元地址是87H,其結(jié)構(gòu)格式如下:

在CHMOS型單片機中,除SMOD位外,其他位均為虛設(shè)的,SMOD是串行口波特率倍增位,當SMOD=1時,串行口波特率加倍。系統(tǒng)復(fù)位默認為SMOD=0。

12、T2CON---T2狀態(tài)控制寄存器

TF2:T2溢出中斷標志。TF2必須由用戶程序清“0”。當T2作為串口波特率發(fā)生器時,TF2不會被置“1”。

EXF2:定時器T2外部中斷標志。EXEN2為1時,當T2EX(P1.1)發(fā)生負跳變時置1中斷標志DXF2,EXF2必須由用戶程序清“0”。

TCLK:串行接口的發(fā)送時鐘選擇標志。TCLK=1時,T2工作于波特率發(fā)生器方式。

RCLK:串行接口的接收時鐘選擇標志位。RCLK=1時,T2工作于波特率發(fā)生器方式。

EXEN2:T2的外部中斷充許標志。

C/T2:外部計數(shù)器/定時器選擇位。C/T2=1時,T2為外部事件計數(shù)器,計數(shù)脈沖來自T2(P1.0);C/T2=0時,T2為定時器,振蕩脈沖的十二分頻信號作為計數(shù)信號。

TR2:T2計數(shù)/定時控制位。TR1為1時充許計數(shù),為0時禁止計數(shù)。

CP/RL2:捕捉和常數(shù)自動再裝入方式選擇位。為1時工作于捕捉方式,為0時T2工作于常數(shù)自動再裝入方式。當TCLK或RCLK為1時,CP/RL2被忽略,T2總是工作于常數(shù)自動再裝入方式。

下面是T2CON的D0、D2、D4、D5幾位主要控制T2的工作方式以及對這幾位的組合關(guān)系進行總結(jié):

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5343

    瀏覽量

    120377
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10863

    瀏覽量

    211781
  • 51單片機
    +關(guān)注

    關(guān)注

    274

    文章

    5702

    瀏覽量

    123623

原文標題:超詳細!關(guān)于51單片機寄存器的功能都在這里講清楚了

文章出處:【微信號:Mouser-Community,微信公眾號:貿(mào)澤電子設(shè)計圈】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    關(guān)于51單片機寄存器功能匯總表

    位地址,可對11個特殊功能寄存器的某些位作位尋址操作(這里介紹一個技巧:其地址能被8整除的都可以位尋址)。 在51單片機內(nèi)部有一個CPU用來運算、控制,有四個并行I/O口,分別是P0、
    的頭像 發(fā)表于 08-24 09:49 ?6717次閱讀
    <b class='flag-5'>關(guān)于</b><b class='flag-5'>51</b><b class='flag-5'>單片機</b><b class='flag-5'>寄存器</b><b class='flag-5'>功能</b>匯總表

    51單片機匯編語言教程_單片機的特殊功能寄存器

    51單片機匯編語言教程:7課單片機的特殊功能寄存器
    發(fā)表于 01-19 15:26 ?0次下載

    51單片機定時寄存器設(shè)置及應(yīng)用詳細

    51單片機定時寄存器設(shè)置及應(yīng)用詳細。
    發(fā)表于 03-28 16:46 ?7次下載

    51單片機寄存器說明

    本資料主要對51單片機常用寄存器配置作了說明
    發(fā)表于 11-18 17:59 ?15次下載

    51單片機寄存器功能一覽表

    本文主要詳細介紹51單片機寄存器功能,首先介紹了51單片機引腳圖及
    發(fā)表于 05-22 16:12 ?5.2w次閱讀
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b><b class='flag-5'>寄存器</b><b class='flag-5'>功能</b>一覽表

    C51單片機特殊功能寄存器的詳細資料說明

    本文檔的主要內(nèi)容詳細介紹的是C51單片機特殊功能寄存器的詳細資料說明。
    發(fā)表于 04-12 18:27 ?4次下載
    C<b class='flag-5'>51</b><b class='flag-5'>單片機</b>特殊<b class='flag-5'>功能</b><b class='flag-5'>寄存器</b>的詳細資料說明

    51單片機的21個特殊功能寄存器的詳細資料說明

    學習51單片機的過程中,其實就是學習怎么用它的特殊功能寄存器(有些寄存器是我們看不到的),特殊功能
    發(fā)表于 09-10 17:26 ?14次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>的21個特殊<b class='flag-5'>功能</b><b class='flag-5'>寄存器</b>的詳細資料說明

    51單片機經(jīng)常使用的寄存器功能總結(jié)

    本文檔的主要內(nèi)容詳細介紹的是51單片機經(jīng)常使用的寄存器功能總結(jié)。
    發(fā)表于 08-29 17:29 ?12次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>經(jīng)常使用的<b class='flag-5'>寄存器</b><b class='flag-5'>功能</b>總結(jié)

    51單片機串口通訊需要注意的寄存器51單片機使用PRINTF的示例程序

    本文檔的主要內(nèi)容詳細介紹的是51單片機進行串口通訊需要注意的寄存器51單片機使用PRINTF的示例程序的詳細資料概述。
    發(fā)表于 08-14 17:32 ?2次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>串口通訊需要注意的<b class='flag-5'>寄存器</b>及<b class='flag-5'>51</b><b class='flag-5'>單片機</b>使用PRINTF的示例程序

    51單片機的一些特殊寄存器資料說明

    本文檔的主要內(nèi)容詳細介紹的是51單片機的一些特殊寄存器資料說明。包括了:中斷使能寄存器,中斷優(yōu)先級寄存器,電源控制PCON,PSW處理
    發(fā)表于 07-26 17:36 ?2次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>的一些特殊<b class='flag-5'>寄存器</b>資料說明

    51單片機的21個特殊功能寄存器詳細資料概述

    在80C51單片機中設(shè)置了與片內(nèi)RAM統(tǒng)一編址的21個特殊功能寄存器(SFR)。訪問SFR只允許使用直接尋址方式。特殊功能
    發(fā)表于 07-09 17:40 ?8次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>的21個特殊<b class='flag-5'>功能</b><b class='flag-5'>寄存器</b>詳細資料概述

    51單片機常用的特殊功能寄存器有哪些

    本文檔的主要內(nèi)容詳細介紹的是51單片機常用的特殊功能寄存器包括了:中斷,串口,定時,電源。
    發(fā)表于 07-08 17:41 ?1次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>常用的特殊<b class='flag-5'>功能</b><b class='flag-5'>寄存器</b>有哪些

    單片機怎么通過按鍵控制計時的開始和停止_超詳細!51單片機寄存器功能一覽表...

    單片機怎么通過按鍵控制計時的開始和停止_超詳細!51單片機寄存器功能一覽表...
    發(fā)表于 11-23 16:22 ?20次下載
    <b class='flag-5'>單片機</b>怎么通過按鍵控制計時<b class='flag-5'>器</b>的開始和停止_超詳細!<b class='flag-5'>51</b><b class='flag-5'>單片機</b><b class='flag-5'>寄存器</b><b class='flag-5'>功能</b>一覽表...

    單片機定時寄存器

    標準的 51 單片機內(nèi)部有 T0 和 T1 這兩個定時,T 就是 Timer 的縮寫,現(xiàn)在很多 51 系列單片機還會增加額外的定時
    發(fā)表于 02-10 12:10 ?1次下載
    <b class='flag-5'>單片機</b>定時<b class='flag-5'>器</b>的<b class='flag-5'>寄存器</b>

    單片機工作寄存器作用 單片機常用專用寄存器

    除了通用寄存器(如累加、通用寄存器等),單片機中還會有特定功能寄存器,如定時
    的頭像 發(fā)表于 04-08 14:46 ?7576次閱讀