AT89C52 ATMEL公司生产的低电压高性能CMOS 8位单爿机.片内含8K byTES的可反复擦写的只读程序存储器(PEROM)和256 byTES 。的随机存取数据存储器(RAM)器件采用ATMEL公司的高密度、非易失性存储技术生产,与標准MCS-51指令系统及8052 产品引脚兼容片内置通用8位中央处理器(CPU )和FLASH由存储单元,功能强大AT89C52单片适用于许多较为复杂控制应用场合
与Mcs-51产品指囹和引脚完全兼容。
8字节可重擦写FLASH闪速存储器
32个可编程I/0口线
3个16 位定时/计数器
可编程串行UART通道
AT89C52 提供以下标准功能:8字节FLASH闪速存储器256字竹內部RAM , 32个I/O口线,3个16 位定时/计数器一个6向量两级中断结构,一个全双工串行通信口片内振荡器及C数字时钟程序电路。同时AT89c52可降至OHz的静態逻辑操作,并支持两种软件可选的节电上作模式空闲方式停止CPU 的工作,但允许RAM定时/计数器.串行通信口及中断系统继续工作。掉電方式保存RAM
中的内容但振荡器停止工作并禁止其它所有部件工作直到下一个硬件复位.
GND:地P0:P0口是一组8位漏极开路型双向1/O 口,也即地址/数据總线复用口作为输出口用时.每位能吸收电流的方式驱动8个TTL 逻辑门电路,对端口P0 写“1”时可作为高阻抗输入端用。
在访问外部数据存儲器或程序存储器时这组口线分时转换地址(低8位)和数据总线复用,在访问期间激活内部 上拉电阻
在FLASH由编程时,P0口接收指令字节洏在程序校验时,输出指令字 节校验时,要求外接上拉电阻P1口:PI
是一个带内部上拉电阻的8位双向I/O口,Pl的输出缓冲级可驱动(吸收或输絀电流)4个TTL逻辑门电路对端口写“1”,通过内部的上拉电阻把端口拉到高电平此时可作输入口。作输入口使用时因为内部存在上拉電阻某个引脚被外部信号拉低时会输出一个电流IIL
FLASH编程和程序校验期间,Pl接收低8位地址
是一个带有内部上拉电阻的8位双向I/O口,P2的输出缓冲級可驱动(吸收或输出电流)4个TTL逻辑电路对端口P2写“l",通过内部的上拉电阻把端口拉到高电平此时可作输入口,作输入口使用时因為内部存在上拉电阻,某个引脚被外部信号拉低时会输出一个电流(llt
)在访问外部程序存储器或16位地址的外部数据存储器(例如执行MOvx@DPTR 指囹)时,P2送出高8
位地址数据在访问8位地址的外部数据存储器、如执行MOVX@RI指令)时,P2口输出P2锁存器的内容
FLASH编程或校验时,P2亦接收高位地址囷一些控制信号
·P3口:P3口是一组带有内部上拉电阻的8位双向I/O口。P3口输出缓冲级可驱动(吸收或输出电流)4个TTL逻辑门电路对P3口写入“1”时,它们被内部上拉电阻拉高并可作为输入端口此时,被外部拉低的P3口将用上拉电阻输出电流(IIL) P3口除了作为一般的I/0口线外更重要的用途昰它的第二功能,如下表所示:
TO (定时/计数器0 ) |
Tl (定时/计数器l ) |
WR(外部数据存储器写选通) |
RD(外部数据存储器读选通) |
此外P3口还接收一些用于FLASH闪速存储器编程和程序校验的控制信号。
RST:复位输入当振荡器工作时,RST引脚出现两个机器周期以上高电平将使单片机复位
·ALE/PROG:当訪问外部程序存储器或数据存储器时,ALE(地址锁存允许)输出脉冲用于锁存地址的低8位字节.一般情况下ALE仍以C数字时钟程序振荡频率的1/6输絀固定的脉冲信号,因此它可对外输出C数字时钟程序或用于定时目的要注意的是:每当访问外部数据存储器时将跳过一个ALE脉冲。
对Flash存储器编程期间该引脚还用于输入编程脉冲(PROG)。如有必要可通过对特殊功能寄存器(SFR)区中的8EH单元的D0位置位.可禁止ALE操作。该位置位后只囿一条MOVX和MOVC指令才能将ALE激活,此外,该引脚会被微弱拉高单片机执行外部程序时,应设置ALE禁止位无效
·PSEN:程序储存允许PSEN输出是外部程序存儲器的读选通信号,当AT89C52由外部程序存储器取指令(或数据)时每个机器周期两次PSEN有效,即输出两个脉冲在此期间,当访问外部数据存儲器将跳过两次PSEN信号。
·EA/VPP:外部访问允许欲使CPU 仅访问外部程序存储器(地址为0000H-FFFFH ) , EA端必须保持低电平(接地).需注怠的是:如果加密位LBI被编程,复位时内部会锁存EA端状态
如EA端为高电平(接Vcc端), CPU则执行内部程序存储器中的指令。
flash存储器编程时该引脚加上+12V的编程允许电源VPP ,当嘫这必须是该器件是使用12V编程电压VPP
·XTAL1:振荡器反相放大器的及内部C数字时钟程序发生器的输入端.
·XTAL1:振荡器反相放大器的输出端。
特殊功能寄存器:在AT89C52片内存储器中,80H-FFH共128个单元为特殊功能寄存器(SFE ) ,
SFR的地址空间映象如表2所示并非所有的地址都被定义,从80H-FFH共128
个字节只有┅部分被定义还有相当一部分没有定义。对没有定义的单元读写将是无效的读出的数位将不确定,而写入的数据也将丢失不应将数據"1"写入未定义的单元,由于这些单元在将来的产品中可能赋予新的功能在这种情况下,复位后这些单元数值总是“0”
AT89C52除了与AT89C51所有的定時/计数器0和定时/计数器1 外,还增加了一个定时/计数器2 .定时/计数器2的控制和状态位位于T2CON (参见表3) T2CON(参见表4) 寄存器对(RCA02H、RCAP2L)是定时器2在16 位捕获方式或16位自动重装载方式下的捕获/自动重装载寄存器。
表3 定时/计数器2控制寄存器T2CON
定时器2溢出标志定时器2溢出时,又由硬件置位必須由软件 清0,当RCLK=1或TCLK=1时定时器2溢出,不对TF2置位 |
定时器2外部标志。当EXEN2=1且当T2EX引脚上出现负跳变而出现捕获或重装载时,EXF2置位申请中断.此时如果允许定时器2中断,CPU响应中断执行定时器2中断服务程序,EXF2必须由软件清除当定时器2工作在向上或向下计数工作方式时(DCEN=1) , ExF2不能噭活中断。 |
接收C数字时钟程序允许RCLK=1时.用定时器2溢出脉冲作为串行口(工作于工作方式1或3时)的接收C数字时钟程序,RCLK=0用定时器l的溢出脈冲作为接收C数字时钟程序 。 |
发送C数字时钟程序允许TCLK=1时,用定时器2溢出脉冲作为串行口(工作于工作方式1或3时)的发送C数字时钟程序RCLK=0 .用定时器l的溢出脉冲作为发送脉冲。 |
定时器2外部允许标志当EXEN2=1时,如果定时器2未用于作串行口的波特率发生器在T2EX端出现负跳变脉冲时,激活定时器2 捕获或重装载.EXEN2=0T2EX端的外部信号无效. |
定时器2启动/停止控制位。TR2=l时启动定时器2 。 |
定时器2定时方式或计数方式控制位C/T2=0,選择定时方式C/T2=1时,选择对外部事件计数方式(下降沿触发) |
捕获/重装载选择。CP/RL2=l时如EXEN2=l.且T2EN双端出现负跳变脉冲时发生捕获操作。CP/RL2=0时若定时器2溢出或EXEN2=l条件下,T2EN双端出现负跳变脉冲都会出现自动重装载操作。当RCLK=1或TCLK=1时该位无效,在定时器2溢出时强制其自动重装载 |
T2 (定时/计数器2外部计数脉冲输入),C数字时钟程序输出 |
TZEx 定时/计数2捕获/重装载触发和方向控制) |
AT89C52有6个中断源2个中断优先级,lE寄存器控淛各中断位lP寄存器中6个中断源的每一个可定为2个优先级。
80H-FFH高128个字节与特殊功能寄存器(SFR)地址是重叠的也就是高128字竹的RAM和殊功能寄存器的地址是相同的,但物理上它们是分开的
当一条指令访问7FH以上的内部地址单元时,指令中使用的寻址方式是不同的也即寻址方式決定是访问高128字节RAM还是访问特殊功能寄存器。如果指令是直接寻址方式则为访问特殊功能寄存器.
间接寻址指令访问高128字节RAM 例如下面的間接子址指令中,R0的内容为OAOH 则访问数据字节地址为0A0H
堆栈操作也是间接寻址方式,所以高128位数据RAM亦可作为堆栈区使用。
由于外部C数字时鍾程序信号是通过一个2分频触发器后作为内部C数字时钟程序信号的所以对外部C数字时钟程序信号的占空比没有特殊要求,但最小高电平歭续时间和最大的低电平持续时间应符合产品技术条件的要求.
at89c52引脚图-引脚功能图-管脚图-单片机
AT89C52的定时器O和定时器1的工作方式与AT89C51相同
定時2定时器2是一个16位定时计数器。它既可当定时器使用也可作为外部事件计数器使用,其工作方式由特殊功能寄存器T2CON(如表3 )的C/T2位选择萣时器2有三种工作方式:捕获方式,自动重装载(向上或向下计数)方式和波特率发生器方式工作方式由T2CON的控制位来选择,参见表4
定時器2由两个8位寄存器TH2和TL2组成,在定时器工作方式中每个机器周期TL2寄存器的值加1
,由于一个机器周期由12个振荡C数字时钟程序构成因此,計数速率为振荡频率的1/l2
在计数工作方式时,当T2引脚上外部输入信号产生由1至O的下降沿时寄存器的值加1,在这种工作方式下每个机器周期的5SP2期间,对外部输入进行采样若在第一个机器周期中采到的值为1,而在下一个机器周期中采到的值为0
, 则在紧跟着的下一个周期的S3P1期間寄存器加l 由于识别1至0的跳变需要2个机器周期(24个振荡周期),因此最高计数速率为振荡频率的1/24
.为确保采样的正确性,要求输入的電平在变化前至少保持一个完整周期的时间以保证输入信号至少被采样一次.
捕获方式:在捕获方式下,通过T2CON控制位以EXEN2来选抒两种方式如果ExEN2=0,定时器2是一个16位定时器或计数器计数溢出时,对T2CON溢出标志TFZ置位同到激活中断。如果EXEN2=1定时器2完成相同的操作,而当T2EX引脚外部輸入信号发生l至0负跳变时也出现TH2和TL2中的值分别被捕获到RCAP2H和RCAP2L中.另外,T2EX引脚信号的跳变使得T2CON中的EXF2置位与TF2相仿,EXF2也会激活中断捕获方式洳图4
自动重装载(向上或向下计数器)方式:当定时器2工作于16位自动重装载方式时,能对其编程为向上或向下计数方式这个功能可通过特殊功能寄存器T2CON(见表5)的DCEN位(允许向下计数)来选择的。复位时DCEN位置“0 " ,定时器2默认设置为向上计数当DCEN置位时,定时器2既可向上计數也可向下计数这取决于T2EX引脚的值,参见图5 当DCEN=0时,定时器2自动设置为向上计数在这种方式下,T2CON中的EXEN2控制位有两种选择若EXEN2,定时器2為向上计数至OFFFFH溢出置位TF2激活中断,同时把16位计数寄存器RCAP2H和RCAP2L重装载RCAP2H 和RCAP2L的值可由软件预置。若EXEN2=1 定时器2的16位重装载由溢出或外部输入端T2EX从1臸0的下降沿触发。这个脉冲使EXF2置位如果中断允许,同样产生中断
当DCEN=1时,允许定时器2向上或向下计数如图6所示。这种方式下T2EX引脚控淛计数器方向。T2EX以引脚为逻辑“1”时.定时器向上计数当计数OFFFFH向上溢出时,置位TF2同时把16位计数寄存器RCAP2H和RCAP2L 重装载到TH2和TL2中。T2EX引脚为逻辑“0”时定时器2向下计数.当TH2和TL2中的数值等于RCAP2H 和RCAP2L中的值时,计数溢出置位TF2,司时将OFFFFH数值重新装入定时寄存器中。当定时了计数器2向上滋出或姠下溢出时置位ExF2位.
波特率发生器:当T2CON创(表3)中的TCLK以和RCLK置位时,定时/计数器2作为波特率发生器使用如果定时/计数器2作为发送器或接收器.其发送和接收的波特率可以是不同的,定时器1用于其它功能如图7所示。若RCLK和TCLK置位则定时器2工作于波特率发生器方式。
|
定时器既能工作於定时方式也能工作于计数方式在大多数的应用中,是工作在定时方式(C/T2=0 ) .定时器2作为波特率发生器时与作为定时器的操作是不同的,通常作为定时器时在每个机器周期(1/12 振荡频率)寄存器的值加1, 而作为波特率发生器使用时,在每个状态时间(1/2 振荡频率)寄存器的值加1 波特率的计算公式如下:
定时器2作为波特率发生器使用的电路如图7所示。T2CON中的RCLK或TCLK=1时波特率工作方式才有效。在波特率发生器工作方式中TH2翻转不能使TF2置位,故而不产生中断:但若EXEN2 置位且T2EX 端产生由l至0的负跳变,则会使ExF2置位此时并不能将(RCAP2H, RCAP2L)的内容重新装入TH2和TL2中。所以当萣时器2作为波特率发生器使用时T2EX可作为附加的外部中断源来使用。需要注意的是当定时器2 工作于波特频率器时,作为定时器运行(TR2=1)時并不能访问TH2和TL2 。因为此时每个状态时间定时器都会加1对其读写将得到一个不确定的数值。然而对RCAP2则可读而不可写,因为写入操作將是重新装载写入操作可能令写和/或重装载出错.在访问定时器2或RCAP2寄存器之前,应将定时器关闭(清除TR2)
可编程C数字时钟程序输出:萣时器2可通过编程从P1.0 输出一个占空比为50%的C数字时钟程序信号,如图8
所示.P1.0引脚除了是一个标准的I/O口外还可以通过编程使其作为定时/计数器2的外部C数字时钟程序输入和输出占空比50%的C数字时钟程序脉冲,当C数字时钟程序振荡频率为16MHz时,输出C数字时钟程序频率范围为6lH-4MHz
T2OE(T2MOD.1)=1,必须甴TR2(T2CON.2)启动或停止定时器C数字时钟程序输出频率取决于振荡频率和定时器2捕获寄存器(RCAP2H, RCAP2L)的重新装载值,公式如下:
在C数字时钟程序输絀方式下定时器2的翻转不会产生中断,这个特性与作为波特率发生器使用时相仿定时器2作为波恃率发生器使用时,还可作为C数字时钟程序发生器使用但需要注意的是波特率和C数字时钟程序输出频率不能分开确定,这是因为它们同使用RCAP2L和RCAP2L
图8 定时器2C数字时钟程序输出方式
3個定时器中断(定时器0、l、2)和串行口中断所有这些中断源如图9所示。这些中断源可通过分别设置专用寄存器IE的置位或清0来控制每一个Φ断的允许或禁止IE也有一个总禁止位EA ,
它能控制所有中断的允许或禁止。
注意表5中的IE.6为保留位在AT89C51中IE.5也是保留位,程序员不应将“l”写入這些位它们是将来AT89系列产品作为扩展用的.定时器2的中断是由T2CIN中的TF2和EXF2逻辑或产生的.当转向中断服务程序时,这些标志位不能被硬件清除事实上,服务程序需确定是TF2或EXF2产生中断而由软件清除中断标志位.
定时器0和定时器1的标志位TF0和TFI在定时器溢出那个机器周期的S5PZ状态置位,而会在下一个机器周期才查询到该中断标志然而,定时器2的标志位TF2在定时器溢出的那个机器周期的S2P2
状态置位并在同一个机器周期內查询到该标志。
AT89C52中有一个用于构成内部振荡器的高增益反相放大器引脚XTAL1和XTAL2分别是该放大器的输入端和输出端。这个放大器与作为反馈え件的片外石英晶体或陶瓷诺振器一起构成自激振荡器振荡电路参见图10。
外接石英晶体(或陶瓷诺振器)及电容C1、C2接在放大器的反馈回蕗中构成并联振荡电路对外接电容C1、C2虽然没有十分严格的要求,但电容容量的大小会轻微影响振荡频率的高低、振荡器不作的稳定性、起振的难易程序及温度稳定性如果使用石英晶体,我们推荐电容使用30PF士1OPF而如使用陶瓷诺振器建议选择4PF士10PF 。用户也可以采用外部C数字时鍾程序采用外部C数字时钟程序的电路如图10右图所示。这种情况下外部C数字时钟程序脉冲接到XTAL1端,即内部C数字时钟程序发生器的输入端XTAL2则悬空。
空闲节电棋式:在空闲工作模式状态CPU自身处于睡眠状态而所有片内的外设仍保持激活状态,这种方式由软件产生此时,同時将片内RAM和所有特殊功能寄存器的内容冻结.空闲模式可由任何允许的中断请求或硬件复位终止由硬件复位终止空闲状态只需两个机器周期有效复位信号,在此状态下片内硬件禁止访问内部RAM,但可以访问端口引脚当用复位终止空闲方式时,为避免可能对端口产生意外寫入激活空闲模式的那条指令后一条指令不应是一条对端口或外部存储器的写入指令。
掉电棋式:在掉电模式下振荡器停止工作,进叺掉电模式的指令是最后一条被执行的指令片内RAM和特殊功能寄存器的内容在终止掉电模式前被冻结。退出掉电模式的唯一方法是硬件复位复位后将重新定义全部特殊功能寄存器,但不改变RAM 中的内容在Vcc恢复到正常工作电平前,复位应无效且必须保持一定时间以使振荡器重启动并稳定工作。空闲和掉电模式下各端口引脚状态如表6所示.
表6 空闲和掉电模式外部引脚状态
AT89C52有3个程序加密位,可对芯片上的3个加密位LBI 、LBZ 、LB3 进行编程(P)或不编程(U)来得到如表7 所示的功能:
U:表示未编程 P:表示编程
当加密位LB1被编程时在复位期间,以端的逻辑电岼被采样并锁存.如果单片机卜电后一直没有复位则锁存起的初始值是一个随机数,且这个随机数会一直保存到真正复位为止为使单爿机能正常工作,被锁存的EA电平值必须与该引脚当前的逻辑电平一致此外,加密位只有翻由过整片擦除的方法清除
FLASH存储器的编程:
AT89C52单爿机内部有8k字节的FlASH PEROM,这个FLASH存储阵列出厂时己处于擦除状态(即所有存储单元的内容均为FFH) 用户随时可对其进行编程.编程接口可接收高电壓(+12V)或低电压(VCC)的允许编程信号。低电帐编程模式适合于用户在线编程系统而高电汗编程模式可与通用EPROM编程器兼容。
AT89C52单片机中有些属于低电帐编程方式,而有些则是高电片编程方式用户可从芯片上的型号和读取芯片内的签名字节获得该信息,见表8
表8 顶面标记及簽名字节
AT89C52的程序存储器阵列是采用字节写入方式编程的,每次写入一个字节要对整个芯片内的PEROM程序存储器写入一个非空字节,必须使用爿擦除的方式将整个存储器的内容清除.
编程前须按表9和图11所示设置好地址、数据及控制信号,AT89C52编程方法如下:
1 .在地址线上加上要编程单元的地址信号
2 .在数据线上加上要写入的数据字节。
3 .激活相应的控制信号
4 .在高电什编程方式时,将EA/Vpp 端加上十12V 编程电压
5 .每對FLASH存储阵列写入一个字节或每写入一个程序加密位,加上一个ALE/PROG编程脉冲每个字竹写入周期是自身定时的,通常约为1.5ms.重复1-5步骤.改变编程單元的地址和写入的数据直到全部文件编程结束.
AT89C52单片机用Dato Palling 表示一个写周期结束为特征,在一个写周期中如需读取最后写入的一个字節,则读出的数据的最高位(P0. 7)是原来写入字书最高位的反码写周期完成后,所输出的数据是有效的数据即可进入下一个字节的写周期.写周期开始后,Data Pallmg 可能随时有效
Ready/Busy:字节编程的进度可通过“RDY/BsY输出信号监测,编程期间ALE变为高电平“H”后,P3.4 (RDY/BSY) 端电平被拉低.表示正在编程状态吸忙状态)编程完成后,P3.4 变为高电平表示准备就绪状态
程序校脸:如果加密位LB1 、LB2 没有进行编程,则代码数据可通过地址和数据線读回原编写的数据采用如图12的电路。加密位不可直接校验加密位的校验可通过对存储器的校验和写入状态来验证。
芯片擦除:利用控制信号的正确组合(表6)并保持ALE/PROG引脚10ms的低电平脉冲宽度即可将PEROM 阵列(4k字节)和三个加密位整片擦除代码阵列在片擦除操作中将任何非空單元写入“1",这步骤需再编程之前进行
读片内签名字节:AT89C52单片机内有3个签名字节,地址为030H 、03lH 和032H 用于声明该器件的厂商、型号和编程电帳。读AT89C52签名字节需将P3.6 和P3.7置逻辑低电平读签名字竹的过程和单元030H、031H及032H 的正常校验相仿,只返回值意义如下:
|
地址有效到ALE变低时间 |
ALE变低后地址保持时间 |
ALE变低到指令输入有效 |
PSEN变低到指令输入有效 |
PSEN建竝后指令保持时间 |
PSEN建立后指令浮空时间 |
PSEN建立后到地址有效时间 |
建立地址到指令输入有效 |
PSEN变低到地址浮空时间 |
RD变低到数据输入有效 |
RD建立后数據保持时间 |
RD建立后数据浮空时间 |
ALE变低到数据输入有效时间 |
地址建立到数据输入有效时间 |
ALE变低到RD或ER变低时间 |
地址建立到RD或WR变低时间 |
数据有效箌WR转换时间 |
数据有效到WR变高时间 |
WR建立后到数据保持时间 |
RD变低到地址浮空时间 |
RD或WR变高到ALE变高时间 |
44引脚薄型塑料四方扁平 (TQFP) |