历史上的今天
返回首页

历史上的今天

今天是:2025年01月14日(星期二)

正在发生

2021年01月14日 | 51单片机特殊功能寄存器功能一览表

2021-01-14 来源:eefocus

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



分别说明如下:




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总是工作于常数自动再装入方式。


下面对T2CON的D0、D2、D4、D5几位主要控制T2的工作方式,下面对这几位的组合关系进行总结



推荐阅读

史海拾趣

Fastron公司的发展小趣事

Fastron公司深知产品质量对于企业的重要性。因此,公司建立了严格的质量控制体系,从原材料采购到产品生产、检测等各个环节都实行严格的质量控制和管理。Fastron还引进了先进的检测设备和技术手段,确保每一款产品都符合高标准的质量要求。这种对品质的执着追求使得Fastron的产品在市场上具有极高的竞争力。

ACCUTEK公司的发展小趣事

ACCUTEK公司深知人才是企业发展的核心力量。因此,公司始终注重人才培养和团队建设。公司建立了完善的人才培养和激励机制,鼓励员工不断学习和创新。同时,公司还注重营造良好的工作氛围和团队文化,让员工能够在轻松愉快的环境中工作。这些举措不仅提升了员工的归属感和忠诚度,也为公司的持续发展提供了有力的人才保障。

这些故事基于电子行业的一般发展规律和可能的企业发展路径构建,并不代表ACCUTEK公司的真实历史。如需了解该公司的真实发展情况,建议查阅相关资料或访问其官方网站。

EiKO Global LLC公司的发展小趣事

为了进一步扩大市场份额,EiKO开始实施全球化战略。公司在美国、加拿大、欧洲和亚太地区设立了办事处,以便更好地服务当地客户。同时,EiKO还积极参加国际照明展会和论坛,与全球同行交流经验和技术,不断提升自身的竞争力。

在全球化布局的过程中,EiKO也面临着各种挑战和困难。然而,公司始终坚持以客户为中心的服务理念,通过不断优化产品和服务质量,赢得了越来越多客户的信赖和支持。

Erocore Enterprise Co Ltd公司的发展小趣事

在快速发展的过程中,Erocore意识到供应链管理的重要性。公司开始优化供应链流程,降低采购成本,提高生产效率。通过与供应商建立长期稳定的合作关系,Erocore在保证产品质量的同时,实现了成本的有效控制。这一举措为公司在激烈的市场竞争中赢得了更多的优势。

聚洵(Gainsil)公司的发展小趣事

在快速发展的过程中,Erocore意识到供应链管理的重要性。公司开始优化供应链流程,降低采购成本,提高生产效率。通过与供应商建立长期稳定的合作关系,Erocore在保证产品质量的同时,实现了成本的有效控制。这一举措为公司在激烈的市场竞争中赢得了更多的优势。

DB Lectro Inc公司的发展小趣事

为了满足亚洲市场的需求,DB Lectro Inc决定在中国上海设立子公司及工厂。这一战略举措不仅使公司能够更贴近亚洲客户,还大大降低了生产成本。在上海工厂的建设过程中,公司充分考虑到环保和可持续性发展的要求,采用了先进的生产工艺和设备。随着工厂的投产和产能的不断提升,DB Lectro Inc的产品在亚洲市场的占有率也稳步上升。

问答坊 | AI 解惑

怎么用单片机控制两个四相步进电机

怎么用单片机控制两个四相步进电机,驱动芯片用哪款最好,电路怎么连接?…

查看全部问答>

论坛的进一步的规划在哪里?

陆续热心的网友提问,有的留下很好的建议,是不是采纳,或者论坛下一步的规划在哪里,管理人员,版主的越来越多,风格不一样,是不是有些共同的准则呢?希望看到一些这个方面的东西,qq集体聊天也可以啊!…

查看全部问答>

请问中断处理中能否进行信号量申请操作?

请问中断处理中能否进行信号量申请操作? …

查看全部问答>

熟悉ARM和xscale的请进,关于系统调用和寄存器。

假如在xscale平台上有个uclinux操作系统,在这个操作系统中执行futex系统调用。 futex系统调用的伪代码: Futex(…) {     if(要进行的是等待操作)         if(指定内存地址中的值与指定的值不相等) ...…

查看全部问答>

nand分区问题

各位,at91sam9261官方bsp~ nand分区: static MapSectionList K9F1208U0A_Offset32MB = {         2,                                ...…

查看全部问答>

fpga&quartus7.2

我使初学者 quartus7.2下编写decoder程序 源代码如下 library ieee; use ieee.std_logic_1164.all; entity decoder is port(sel:std_logic_vector(2 downto 0);         enable:std_logic;         ...…

查看全部问答>

万利的199的板子到哪儿买?直接找万利吗?

                                  …

查看全部问答>

为什么我的quartus仿真只能到49%,就没反应了

代码编译通过,然后用quartus仿真,结果仿真进度只能到达49%,然后就没反应了,它页不会报错,我的代码没问题啊。 各位,在你们的quartus上仿真看看,是怎么回事啊?谢谢 期待你们的回答。…

查看全部问答>

【MSP430共享】基于事件-目标驱动的人机界面设计

人机 界 面 ( h u ma n - c o mp u t e r   i n t e r f a c e ) , 又 称 用户 界面、 人机交互、 人机接 口等, 是人与机器之间传递、 交换信息的媒介, 是用户使用计算机系统的综合操作环境。在商品竞争 中, 一个应用系统的成功与否 ...…

查看全部问答>

PCIE2.0 发现不了设备

有做过PCIE的么,我现在遇到个问题,PCIE 2.0 ×1程序烧进去后,发现不了设备,而×4和×8却都能,数据传输也有,请问 有知道的大侠么,谢谢!…

查看全部问答>