微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 51单片机特殊功能寄存器(SFR)介绍

51单片机特殊功能寄存器(SFR)介绍

时间:12-01 来源:互联网 点击:

#define LCD_RS_1 GPIOE->

P IE

定时器相关:TMOD TCON TL0、TH0、TL1、TH1

串口通信相关:SCONPCON SBUF

这15个寄存器中,P1 P2 P3 P4 TL0 TH0 TL1 TH1 SBUF这9个操作相对简单,而PCON为电源控制寄存器,平时只有在串口通信编程中会用到最高位SMOD,当SMOD=1,波特率会倍增,所以对这个寄存器只需要考虑这点就可以了,而对于IP寄存器为中断优先寄存器,对于单片机初学者基本上用不到,这里先不作介绍。

剩下的就只有IE、TCON、SCON和TMOD4个寄存器了,如图1中绿色圆圈的四个,分别为中断允许寄存器(IE),定时器控制寄存器(TCON),定时器模式及工作方式寄存器(TMOD),串行口控制寄存器(SCON)。4个寄存器相对来说较难记住,下面分别对这4个寄存器及每一位进行说明。

1、IE中断允许寄存器

EA:EA=0时,所有中断禁止(即不产生中断);EA=1时,各中断的产生由个别的允许位决定

ET2:定时2溢出中断允许(8052用1允许,0禁止)

ES:串行口中断允许(1允许,0禁止)

ET1):定时1中断允许(1允许,0禁止)

EX1:外中断INT1中断允许(1允许,0禁止)

ET0:定时器0中断允许(1允许,0禁止)

EX0:外部中断INT0的中断允许(1允许,0禁止)

2、TCON定时器控制寄存器

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。此位为1设置为电平触发,为0设置为下降沿触发。

IE0:外部中断0请示源(INT0,P3.2)标志。IE0=1,外部中断1正在向CPU请求中断,当CPU响应该中断时由硬件清“0”IE0(边沿触发方式)。

IT0:外部中断源0触发方式控制位。IT0=0,外部中断1程控为电平触发方式,当INT0(P3.2)输入低电平时,置位IE0。此位为1设置为电平触发,为0设置为下降沿触发。

3、TMOD定时器工作模式及方式寄存器

此寄存器高四位用于T1,低四位用于T0。

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:0 0方式0,13位计数/计时器

M1 M0:0 1方式1,16位计数/计时器

M1 M0:1 0方式2,8位自动加载计数/计时器

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

4、SCON串行通信控制寄存器


SM0 SM1:串行口工作方式控制位

SM0 SM1:0 0方式0-波特率由振荡器频率所定:振荡器频率/12

SM0 SM1:0 1方式1-波特率由定时器T1或T2的溢出率和SMOD所定:2SMOD ×(T1溢出率)/32

SM0 SM1:1 0方式2-波特率由振荡器频率和SMOD所定:2SMOD ×振荡器频率/64

SM0 SM1: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可由

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top