单片机学习笔记特殊功能寄存器

发布者:温暖的微风最新更新时间:2016-05-17 来源: eefocus关键字:单片机学习  特殊功能寄存器 手机看文章 扫描二维码
随时随地手机看文章
 21个特殊功能寄存器(52系列是26个)不连续地分布在128个字节的SFR存储空间中,地址空间为80H-FFH,在这片SFR空间中,包含有128个位地址空间,地址也是80H-FFH,但只有83个有效位地址,可对11个特殊功能寄存器的某些位作位寻址操作(这里介绍一个技巧:其地址能被8整除的都可以位寻址)。

 

  在51单片机内部有一个CPU用来运算、控制,有四个并行I/O口,分别是P0、P1、P2、P3,有ROM,用来存放程序,有RAM,用来存放中间结果,此外还有定时/计数器,串行I/O口,中断系统,以及一个内部的时钟电路。在单片机中有一些独立的存储单元是用来控制这些器件的,被称之为特殊功能寄存器(SFR)。这样的特殊功能寄存器51单片机共有21个并且都是可寻址的列表如下(其中带*号的为52系列所增加的特殊功能寄存器):

MCS-51单片机的特殊功能寄存器
符号 地址 功能介绍

B

F0H

B寄存器

ACC 

E0H

累加器

PSW  

D0H

程序状态字

TH2* CDH 定时器/计数器2(高8位)
TL2* CCH 定时器/计数器2(低8位)
RCAP2H* CBH 外部输入(P1.1)计数器/自动再装入模式时初值寄存器高八位
RCAP2L* CAH 外部输入(P1.1)计数器/自动再装入模式时初值寄存器低八位
T2CON* C8H T2定时器/计数器控制寄存器

IP 

B8H

中断优先级控制寄存器

P3 

B0H

P3口锁存器

IE 

A8H

中断允许控制寄存器

P2 

A0H

P2口锁存器

SBUF

99H

串行口锁存器

SCON

98H

串行口控制寄存器

P1 

90H

P1口锁存器

TH1  

8DH

定时器/计数器1(高8位)

TH0

8CH

定时器/计数器1(低8位)

TL1

8BH

定时器/计数器0(高8位)

TL0  

8AH

定时器/计数器0(低8位)

TMOD

89H

T0、T1定时器/计数器方式控制寄存器

TCON

88H

T0、T1定时器/计数器控制寄存器

DPH  

83H

数据地址指针(高8位)

DPL

82H

数据地址指针(低8位)

SP

81H

堆栈指针

P0

80H

P0口锁存器

PCON

87H

电源控制寄存器

 

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



分别说明如下:

 

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

  这是个什么东西,可不能从名字上理解,它是一个寄存器,而不是一个做加法的东西,为什么给它这么一个名字呢?或许是因为在运算器做运算时其中一个数一定是在ACC中的缘故吧。它的名字特殊,身份也特殊,稍后在中篇中我们将学到指令,可以发现,所有的运算类指令都离不开它。自身带有全零标志Z,若A=0则Z=1;若A≠0则z=0。该标志常用作程序分枝转移的判断条件。

2、B--一个寄存器

  在做乘、除法时放乘数或除数,不做乘除法时,随你怎么用。

3、PSW-----程序状态字。

  这是一个很重要的东西,里面放了CPU工作时的很多状态,借此,我们可以了解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)

AC:辅助进、借位(高半字节与低半字节间的进、借位)。

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

F0:用户标志位

  由用户(编程人员)决定什么时候用,什么时候不用。
RS1、RS0:工作寄存器组选择位

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

工作寄存器区选择
RS1 RS0 当前使用的工作寄存器区R0~R7
0 0 0区(00~07H)
0 1 1区(08~0Fh)
1 0 2区(10~17h)
1 1 3区(18~1Fh)

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

IE 中断充许寄存器

B7

B6

B5

B4

B3

B2

B1

B0

EA

-

ET2

ES

ET1

EX1

ET0

EX0

  • 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 中断优先级控制寄存器

B7

B6

B5

B4

B3

B2

B1

B0

- 

-

PT2

PS

PT1

PX1

PT0

PX0

  • - (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

TMOD 定时器控制寄存器

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工作模式选择位
M1 、M0:T0、T1工作模式选择位

M1

M0

工作模式

0

0

方式0,13位计数/计时器

0

1

方式,1,16位计数/计时器

1

0

方式2,8位自动加载计数/计时器

1

1

方式3,仅适用于T0,定时器0分为两个独立的8位定时器/计数器TH0及TL0,T1在方式3时停止工作

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

可按位寻址,地址位88H

TCON 定时器控制寄存器

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。

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

  它是一个可寻址的专用寄存器,用于串行数据的通信控制,单元地址是98H,其结构格式如下:

SCON 串行通信控制寄存器
D7 D6 D5 D4 D3 D2 D1 D0
SM0 SM1 SM2 REN TB8 RB8 TI RI

(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,其结构格式如下:

PCON电源管理寄存器结构
D7 D6 D5 D4 D3 D2 D1 D0
SMOD - - - GF1 GF0 PD IDL

  在CHMOS型单片机中,除SMOD位外,其他位均为虚设的,SMOD是串行口波特率倍增位,当SMOD=1时,串行口波特率加倍。系统复位默认为SMOD=0。

12、T2CON-----T2状态控制寄存器

T2CON 定时器控制寄存器

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的工作方式,下面对这几位的组合关系进行总结

定时器T2方式选择
RCLK+TCLK CP/RL2 TR2 工作方式
0 0 1 16位常数自动再装入方式
0 1 1 16位捕捉方式
1 × 1 串行口波特率发生器方式
× × 0 停止计数

关键字:单片机学习  特殊功能寄存器 引用地址:单片机学习笔记特殊功能寄存器

上一篇:单片机学习笔记51单片机基础
下一篇:单片机学习笔记嵌入式介绍

推荐阅读最新更新时间:2024-03-16 14:54

51单片机学习:LED点阵实验(显示数字)
实验名称:LED点阵实验(显示数字) 接线说明: 实验现象:下载程序后,8*8LED点阵显示数字0 注意事项:LED点阵旁的J24黄色跳线帽短接到GND一端 ***************************************************************************************/ #include reg51.h typedef unsigned int u16; //对系统默认数据类型进行重定义 typedef unsigned char u8; //定义74HC595控制管脚 sbit SRCLK=P3^6; //移位寄存器时钟输入 sbit RCLK=P3^5; //存
[单片机]
PIC单片机学习7 TMR1
TMR1是16位宽度的TMR1由2个8位的可读写的寄存器TMR1H和TMR1L组成。 TMR1有专门的启停控制位TMR1ON,通过软件可以任意启动或暂停TMR1计数功能。 T1CON:TIMER1 CONTROL REGISTER bit7-6 unimplemented :Read as ‘0’ bit5-4 T1CKPS1:T1CKPS0:Timer1 input Clock Prescale Select bits 11=1:8 prescale value 10=1:4 prescale value 01=1:2 prescale value 00=1:1 prescale va
[单片机]
51单片机学习:步进电机实验
实验名称:步进电机实验 接线说明: 实验现象:下载程序后,当按下KEY1键可调节电机旋转方向;当按下KEY2键,电机加速; 当按下KEY3键,电机减速 注意事项:将步进电机红色线对接到“步进电机模块”输出端子J47的5V上,其它相序依次接入。 ***************************************************************************************/ #include reg52.h typedef unsigned int u16; //对系统默认数据类型进行重定义 typedef unsigned char u8; //定义ULN2003控制步进电机管脚 s
[单片机]
51单片机学习:ADC模数转换实验--电位器电压采集
实验名称:ADC模数转换实验--电位器电压采集 接线说明: 实验现象:下载程序后,数码管上显示AD模块采集电位器的电压值 注意事项: ***************************************************************************************/ #include public.h #include smg.h #include xpt2046.h /******************************************************************************* * 函 数 名 : main * 函数功能 : 主函数 *
[单片机]
技术牛人自制STM32开发板学习32位单片机(图文)
  实验室快关门了,于是赶着这时间把一直想搞的STM32开发板给做了,顺便把那个2.4寸TFT的转接板也做了,加了个触摸屏。这里上传我的资料。希望对网友有帮助。   我一贯是以实用至上,这次也不例外,开发板分为核心板和主板,主板提供核心板的必要外围设备,同时在没有核心板的时候,主板就成了一个通用的了,为其他核心板(像我做的CPLD/ADUC7027之类的)提供外设了。主板载有功能:   STM32开发板LCD显示效果   1,5V,3.3V电源输出(由USB供电或者外部电源都可)   2,USB串口一个(CH341),通用串口2个(MAX232)   3.USB接口一个,支持U盘或者与电脑连接   4,按键三个
[单片机]
技术牛人自制STM32开发板<font color='red'>学习</font>32位<font color='red'>单片机</font>(图文)
51单片机学习笔记——基于汇编语言(2)
这篇起博主要开始讲51系列单片机的汇编指令了,我们需要环境Keil,版本无所谓,都差不多,至于keil怎么建工程不用博主说吧,这个大家可以自行百度 1.汇编指令 1.1指令格式 操作码 , , ; 注释 整个语句必须在一行内写完 (1)标号:指令的地址符 (2)操作码:表示指令的操作功能 (2)操作数:参加操作的数据或数据地址 (4)注释:指令功能说明 1.2指令分类 1Byte:操作码 2Byte:操作码 数据或寻址方式 3Byte:操作码 数据或寻址方式 数据或寻址方式 1.3操作数类型 (1)立即数 立即数作为指令代码的一部分出现在指令中,通常作为源操作数使用。 立即数符“#” 例: #12H 表示8位立即数1
[单片机]
51单片机学习笔记(二)
按照教材,昨天学到了检测按键的程序,也很明确昨天学那个程序难登大雅之堂,因为它没有实现按键在闭合和开关时的电压信号抖动。 如图示,键按下试产生多个抖动的波形,也就是产生了多个101010,而我们实际中只是两个状态只是1,或只是0。所以收集了干扰信号。于是就有今天我学的“去抖动程序” 去抖原理:收到第一个低电平信号(按下的信号)后,开始延迟再次收集信号,再确认是否低电平(一直被按下)这时收集的信息就来自抖动波形图的中间部分,所以只要这个时间段是低电平,按键就肯定被按下了,不会再有抖动。这时就跳到指令检测这个按键引脚什么时候变为高电平(表示释放按键),不断循环检测,直至按键被释放。检测到释放信号后,就有cpl指令修改相应led灯
[单片机]
C51单片机学习(二):中断系统和定时器
中断系统: 中断概念 CPU在处理某一事件A时,发生了另一事件B请求CPU迅速去处理(中断发生); CPU暂时中断当前的工作,转去处理事件B(中断响应和中断服务); 待CPU将事件B处理完毕后,再回到原来事件A被中断的地方继续处理事件A(中断返回),这一过程称为中断 。 中断的结构图 其中一些说明: 1、(P3.2)可由IT0(TCON.0)选择其为低电平有效还是下降 沿有效。当CPU检测到P3.2引脚上出现有效的中断信号时, 中断标志IE0(TCON.1)置1,向CPU申请中断。 2、(P3.3)可由IT1(TCON.2)选择其为低电平有效还是下降沿有效。当CPU检测到P3.3引脚上出现有效的中断信号时,中
[单片机]
C51<font color='red'>单片机</font><font color='red'>学习</font>(二):中断系统和定时器
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
更多每日新闻
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved