52单片机特殊功能寄存器合集(26种)

21个特殊功能寄存器(52系列是26个)不连续的分布在128个字节的SFR存储空间中,地址空间为80H-FFH,在这片SFR空间中,包含有128个位地址空间,地址也是80H-FFH,但只有83个有效位地址,可对11个特殊功能寄存器的某些位作位寻址操作(其地址能被8整除的都可以位寻址)

总介绍

52单片机特殊功能寄存器合集
符号 地址 功能介绍
B F0H B寄存器
ACC 0H 累加器
PSW D0H 程序状态字
TH0 8CH 定时器/计数器1(低8位)
TH1 8DH 定时器/计数器1(高8位)
TH2 CDH 定时器/定时器/计数器1
TL0 8AH 定时器/计数器0(低8位)
TL1 8BH 定时器/计数器1(高8位)
TL2 CCH 定时器/计数器2(低8位)
T2CON C8H T2定时器/计数器控制寄存器
RCAP2H CBH 外部输入(P1 1)计数器/自动再装入模式时初始寄存器高8位
RCAP2L CAH 外部输入(P1 1)计数器/自动再装入模式时初始寄存器低8位
IP B8H 中断优先级控制寄存器
IE A8H 中断允许控制寄存器
P1 90H P1口锁存器
P2 A0H P2口锁存器
P3 B0H P3口锁存器
P0 80H P0口锁存器
SBUF 99H 串行口锁存器
SCON 98H 串行口控制寄存器
TMOD 89H T0、T1定时器/计数器方式控制寄存器
TCON 88H T0、T1定时器/计数器控制寄存器
DPH 83H 数据地址指针(高8位)
DPL 82H 数据地址指针(低8位)
SP 81H 堆栈指针
PCON 87H 电源控制寄存器

分部介绍

ACC

  • 累加器,通常用A表示
  • 不是一个做加法的东西,它是一个寄存器
  • 所有的运算类指令都离不开它
  • 自身带有全零标志Z
  • 若A=0则Z=1,若A不为0则Z=0,该标志常用作程序分支转移的判断条件

B

  • 寄存器
  • 做乘除法的时候放出乘数或除数,不做乘除法时,随便怎么用

PSW

  • 程序状态字
  • 内存储了CPU工作时的很多状态
  • 它的各位功能如下表
PSW程序状态字
D7 D6 D5 D4 D3 D2 D1 D0
CY AC F0 RS1 RS0 OV P
  • CY:进位标志位,8051中的运算器是一种8位的运算器,8位运算器只能表示到0-255,但如果做加法,两数相加可能会超过255,这样最高位就会丢失,造成运算的错误,这时候最高位就进到这里来。有进、借位,CY=1;无进、借位,CY=0。

    • 例如78H+97H(01111000+10010111),此时CY=1。
  • AC:半进位(辅助进、借位,(高半字节与低半字节间的进、借位))

  • F0:用户标志位,由用户(编程人员)决定什么时候用,什么时候不用。

  • RS1、RS0:工作寄存器组选择位

    • 通过修改PSW中的RS0、RS1两位的状态,就能任选一个工作寄存器区。这个特点提高了8051现场保护和现场恢复的速度。对于提高CPU的工作效率和响应中断的速度是很有利的。若在一个实际的应用系统中,不需要四组工作寄存器,那么这个区域中多余单元可以作为一般的数据缓冲器使用。
  • OV:溢出标志位

    • 运算结果按补码运算理解。有溢出,OV=1;无溢出,OV=0
  • P:奇偶校验位

    • 表示二进制数位“1”的个数的奇偶性,若为计数,则P=1.否则为0 。运算结果有奇数个1,P=1;运算结果有偶数个1,P=0。
    • 例:某运算结果是78H(011110000),显然1的个数为偶数,所以P=0。

DPTR(DPH、DPL)

  • 数据指针
  • 可以用它来访问外部数据存储器中的任意单元,如果不用,也可以作为通用寄存器来用,分成DPL(低8位)和DPH(高8位)两个寄存器。用来存放16位地址值,以便用间接寻址或变址寻址的方式对片外数据RAM或程序存储器作64K字节范围内的数据操作。

P0、P1、P2、P3

  • 输入输出口寄存器

  • 四个并行输入输出的寄存器,它里面的内容对应着管脚的输出。

IE

  • 中断充许寄存器
B7 B6 B5 B4 B3 B2 B1 B0
EA - ET2 ES ET1 EX1 ET0 EX0
  • EA:当EA=0时,所有中断禁止(即不产生中断);EA=1时,各中断的产生由个别的允许位决定。
  • B6:保留位
  • ET2:定时2溢出中断充许(8052用)
  • ES:串行口中断充许(ES=1充许,ES=0禁止)
  • ET1:定时1中断充许
  • EX1:外中断INT1中断充许

IP

  • 中断优先级控制寄存器,可按位寻址,地址位B8H

  • B7 B6 B5 B4 B3 B2 B1 B0
    - - PT2 PS PT1 PX1 PT0 PX0
    • IP7,IP6:保留位
    • PT2:定时2中断优先(8052用)
    • PS:串行口中断优先
    • PT1:定时1中断优先
    • PX1:外中断INT1中断优先
    • PT0:定时器0中断优先
    • PX0:外部中断INT0的中断优先

TMOD

  • 定时器控制寄存器

  • 不按位寻址,地址89H

  • B7 B6 B5 B4 B3 B2 B1 B0
    GATE C/T M1 M0 GATE C/T M1 M0
    • 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工作模式选择位

TCON

  • 定时器控制寄存器

  • 可按位寻址,地址位88H

  • B7 B6 B5 B4 B3 B2 B1 B0
    TF1 TR1 TF0 TR0 IE1 IT1 IE0 IT0
    • 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。

SCON

  • 串行通信控制寄存器

  • 可寻址的专用寄存器,地址位98H

  • 用于串行数据的通信控制

  • D7 D6 D5 D4 D3 D2 D1 D0
    SM0 SM1 SM2 REN TB8 RB8 TI RI
    • SM0、SM1:串行口工作方式控制位
    SM0 SM1 方式 工作方式
    0 0 0 波特率由振荡器频率所定:振荡器频率/12
    0 1 1 波特率由定时器T1或T2的溢出率和SMOD所定:2SMOD ×(T1溢出率)/32
    1 0 2 波特率由振荡器频率和SMOD所定:2SMOD ×振荡器频率/64
    1 1 3 波特率由定时器T1或T2的溢出率和SMOD所定:2SMOD ×(T1溢出率)/32
    • SM2:多机通信控制位。多机通信是工作于方式2和方式3,SM2位主要用于方式2和方式3。接收状态,当串行口工作于方式2或3,以及SM2=1时,只有当接收到第9位数据(RB8)为1时,才把接收到的前8位数据送入SBUF,且置位RI发出中断申请,否则会将接受到的数据放弃。当SM2=0时,就不管第位数据是0还是1,都难得数据送入SBUF,并发出中断申请。工作于方式0时,SM2必须为0

    • REN:允许接收位 。REN用于控制数据接收的允许和禁止,REN=1时,允许接收,REN=0时,禁止接收。

    • TB8:发送接收数据位8。在方式2和方式3中,TB8是要发送的——即第9位数据位。在多机通信中同样亦要传输这一位,并且它代表传输的地址还是数据,TB8=0为数据,TB8=1时为地址。

    • RB8:接收数据位8。在方式2和方式3中,RB8存放接收到的第9位数据,用以识别接收到的数据特征。

    • TI:发送中断标志位。

      可寻址标志位。方式0时,发送完第8位数据后,由硬件置位,其它方式下,在发送或停止位之前由硬件置位,因此,TI=1表示帧发送结束,TI可由软件清“0”。

    • RI:接收中断标志位。

      可寻址标志位。接收完第8位数据后,该位由硬件置位,在其他工作方式下,该位由硬件置位,RI=1表示帧接收完成

PCON

  • 电源管理寄存器,地址位87H

  • 主要是为CHMOS型单片机的电源控制而设置的专用寄存器

  • D7 D6 D5 D4 D3 D2 D1 D0
    SMOD - - - GF1 GF0 PD IDL
    • 在CHMOS型单片机中,除SMOD位外,其他位均为虚设的,SMOD是串行口波特率倍增位,当SMOD=1时,串行口波特率加倍,系统默认为SMOD=0

T2CON

  • T2状态控制寄存器

  • B7 B6 B5 B4 B3 B2 B1 B0
    TF2 EXF2 RCLK TCLK EXEN2 TR2 C/T2 CP/RL2
    • 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总是工作于常数自动再装入方式。
    • 下面对T2CON的D0、D2、D4、D5几位主要控制T2的工作方式,下面对这几位的组合关系进行总结

进制转换

二进制转换

  • 二进制转换为8进制

    以每三位划分,从小数点算,左侧的在左边补0,小数点右侧的在右边补0.

    比如(1011101.1011)2=(135.54)8(1011101.1011)_2=(135.54)_8

    001/011/101=135

    101/100=54

二进制 八进制 十进制 十六进制
0000 0 0 0
0001 1 1 1
0010 2 2 2
0011 3 3 3
0100 4 4 4
0101 5 5 5
0110 6 6 6
0111 7 7 7
1000 8 8
1001 9 9
1010 10 A
1011 11 B
1100 12 C
1101 13 D
1110 14 E
1111 15 F
  • 二进制转化为十进制

小数点前一位是第0位,所以(1011101.101)2=(1×26+0×25+1×24+1×23+1×22+0×21+1×20+1×21+1×22+1×23)10(1011101.101)_2=(1×2^6+0×2^5+1×2^4+1×2^3+1×2^2+0×2^1+1×2^0+1×2^{-1}+1×2^{-2}+1×2^{-3})_{10}

(1011101.101)2=(93.625)10(1011101.101)_2=(93.625)_{10}

  • 二进制转化为十六进制

与转化为八进制相像,只不过这个取4位

(1011101.101)2=(0101/1101.1010)16=(5D.A)16(1011101.101)_2=(0101/1101.1010)_{16}=(5D.A)_{16}

八进制转换

  • 八进制转化为二进制

根据最上面图表三个三个一一对应即可

(55.3)8=(101/101.011)2(55.3)_8=(101/101.011)_2

  • 八进制转化为十进制

方法相同

(55.3)8=(5×81+5×80.3×81)10=(45.375)10(55.3)_8=(5×8^1+5×8^0.3×8^{-1})_{10}=(45.375)_{10}

  • 八进制转换十六进制

八进制需要先转换成二进制,再转换成十六进制

(55.3)8=(101101.011)2=(2D.6)16(55.3)_8=(101101.011)_2=(2D.6)_{16}

十进制转换

  • 十进制转换二进制

辗转相除法,这次除2,小数点之前从上到下数,小数点之后从上到下数

(59.25)10=(111011.01)2(59.25)_{10}=(111011.01)_2

  • 十进制转换为八进制

同理也用辗转相除法,这次除8

(3459.25)10=(6603.2)8(3459.25)_{10}=(6603.2)_8

  • 十进制转换十六进制

辗转相除法,除16,大于10的就ABC

(2734459.25)10=(42C33.4)16(2734459.25)_{10}=(42C33.4)_{16}

十六进制转换

  • 十六进制转换为二进制

(39C.D8)16=(0011/1001/1100.11011)2=(1110011100.11011)2(39C.D8)_{16}=(0011/1001/1100.11011)_2=(1110011100.11011)_{2}

  • 十六进制转换八进制

三位一体,十六进制解出二进制,再二进制转换为8进制

(39C.D8)16=(1110011100.11011)2=(001/110/011/100.110/110)8(39C.D8)_{16}=(1110011100.11011)_2=(001/110/011/100.110/110)_8

(39C.D8)16=(1634.66)8(39C.D8)_{16}=(1634.66)_8

  • 十六进制转换为十进制

(39D.D8)16=(3×162+9×161+12×160+)10=(924.8437)10(39D.D8)_{16}=(3×16^2+9×16^1+12×16^0+)_10=(924.8437)_{10}