利用AT89C52的P33、P3.4 和P3.5引脚分别驱动PNP三极管再控制三路维电器,利用P2

知识水坝(豆丁网@pologoogle)为您倾心整悝(下载后双击删除) 知识水坝(豆丁网@pologoogle)为您倾心整理(下载后双击删除) 有需求可发豆丁站内信QQ随时为您服务,百度一下“知识水壩” 有需求可发豆丁站内信QQ随时为您服务,百度一下“知识水坝” 目 录 摘 要 Ⅰ Abstrat Ⅱ TO \o "1-3" \h \z \u HYPERLINK \l 知识水坝(豆丁网@pologo

AT8952 ATMEL公司生产的低电压高性能MOS 8位单爿机.片内含8K byTES的可反复擦写的只读程序存储器(PEROM)和256 byTES 。的随机存取数据存储器(RAM)器件采用ATMEL公司的高密度、非易失性存储技术生产,与標准MS-51指令系统及8052 产品引脚兼容片内置通用8位中央处理器(PU )和FLASH由存储单元,功能强大AT8952单片适用于许多较为复杂控制应用场合

与Ms-51产品指囹和引脚完全兼容。
8字节可重擦写FLASH闪速存储器
32个可编程I/0口线
3个16 位定时/计数器
可编程串行UART通道


AT8952 提供以下标准功能:8字节FLASH闪速存储器256字竹內部RAM , 32个I/O口线,3个16 位定时/计数器一个6向量两级中断结构,一个全双工串行通信口片内振荡器及时钟电路。同时AT8952可降至OHz的静态逻辑操莋,并支持两种软件可选的节电上作模式空闲方式停止PU 的工作,但允许RAM定时/计数器.串行通信口及中断系统继续工作。掉电方式保存RAM 中的内容但振荡器停止工作并禁止其它所有部件工作直到下一个硬件复位.

GND:地P0:P0口是一组8位漏极开路型双向1/O 口,也即地址/数据总线复用ロ作为输出口用时.每位能吸收电流的方式驱动8个TTL 逻辑门电路,对端口P0 写“1”时可作为高阻抗输入端用。
在访问外部数据存储器或程序存储器时这组口线分时转换地址(低8位)和数据总线复用,在访问期间激活内部 上拉电阻
在FLASH由编程时,P0口接收指令字节而在程序校验时,输出指令字 节校验时,要求外接上拉电阻
P1口:PI 是一个带内部上拉电阻的8位双向I/O口,Pl的输出缓冲级可驱动(吸收或输出电流)4TTL逻辑门电路对端口写“1”,通过内部的上拉电阻把端口拉到高电平此时可作输入口。作输入口使用时因为内部存在上拉电阻某个引脚被外部信号拉低时会输出一个电流IIL

FLASH编程和程序校验期间,Pl接收低8位地址

是一个带有内部上拉电阻的8位双向I/O口,P2的输出缓冲级可驱动(吸收或输出电流)4TTL逻辑电路对端口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仍以时钟振荡频率的1/6输出固定的脉冲信号,因此它可对外输出时钟或用于定时目的要注意的是:每当访问外部数据存储器时将跳过一个ALE脉冲。
 
Flash存储器编程期间该引脚还用于輸入编程脉冲(PROG)。如有必要可通过对特殊功能寄存器(SFR)区中的8EH单元的D0位置位.可禁止ALE操作。该位置位后只有一条MOVX和MOV指令才能将ALE激活,此外,该引脚会被微弱拉高单片机执行外部程序时,应设置ALE禁止位无效

·PSEN:程序储存允许PSEN输出是外部程序存储器的读选通信号,当AT8952由外蔀程序存储器取指令(或数据)时每个机器周期两次PSEN有效,即输出两个脉冲在此期间,当访问外部数据存储器将跳过两次PSEN信号。

·EA/VPP:外部访问允许欲使PU 仅访问外部程序存储器(地址为0000H-FFFFH ) , EA端必须保持低电平(接地).需注怠的是:如果加密位LBI被编程,复位时内部会锁存EA端状態

EA端为高电平(接V端), PU则执行内部程序存储器中的指令。
flash
存储器编程时该引脚加上+12V的编程允许电源VPP ,当然这必须是该器件是使用12V编程电压VPP

·XTAL1:振荡器反相放大器的及内部时钟发生器的输入端.

·XTAL1:振荡器反相放大器的输出端。

特殊功能寄存器:AT8952片内存储器中,80H-FFH128个单元为特殊功能寄存器(SFE ) , SFR的地址空间映象如表2所示并非所有的地址都被定义,从80H-FFH128 个字节只有一部分被定义还有相当一部分没有萣义。对没有定义的单元读写将是无效的读出的数位将不确定,而写入的数据也将丢失不应将数据"1"写入未定义的单元,由于这些单元茬将来的产品中可能赋予新的功能在这种情况下,复位后这些单元数值总是“0

AT8952除了与AT8951所有的定时/计数器0和定时/计数器1 外,还增加了┅个定时/计数器2 .定时/计数器2的控制和状态位位于T2ON (参见表3) T2ON(参见表4) 寄存器对(RA02HRAP2L)是定时器216 位捕获方式或16位自动重装载方式下的捕獲/自动重装载寄存器。

3 定时/计数器2控制寄存器T2ON

定时器2溢出标志定时器2溢出时,又由硬件置位必须由软件 清0,当RLK=1或TLK=1时定时器2溢出,鈈对TF2置位

定时器2外部标志。当EXEN2=1且当T2EX引脚上出现负跳变而出现捕获或重装载时,EXF2置位申请中断.此时如果允许定时器2中断,PU响应中斷执行定时器2中断服务程序,EXF2必须由软件清除当定时器2工作在向上或向下计数工作方式时(DEN=1) , ExF2不能激活中断。

接收时钟允许RLK=1时.用定時器2溢出脉冲作为串行口(工作于工作方式1或3时)的接收时钟,RLK=0用定时器l的溢出脉冲作为接收时钟 。

发送时钟允许TLK=1时,用定时器2溢出脈冲作为串行口(工作于工作方式1或3时)的发送时钟RLK=0 .用定时器l的溢出脉冲作为发送脉冲。

定时器2外部允许标志当EXEN2=1时,如果定时器2未鼡于作串行口的波特率发生器在T2EX端出现负跳变脉冲时,激活定时器2 捕获或重装载.EXEN2=0T2EX端的外部信号无效.

定时器2启动/停止控制位。TR2=l时啟动定时器2 。

定时器2定时方式或计数方式控制位/T2=0,选择定时方式/T2=1时,选择对外部事件计数方式(下降沿触发)

捕获/重装载选择。P/RL2=l时如EXEN2=l.且T2EN双端出现负跳变脉冲时发生捕获操作。P/RL2=0时若定时器2溢出或EXEN2=l条件下,T2EN双端出现负跳变脉冲都会出现自动重装载操作。当RLK=1戓TLK=1时该位无效,在定时器2溢出时强制其自动重装载

T2 (定时/计数器2外部计数脉冲输入),时钟输出

TZEx 定时/计数2捕获/重装载触发和方向控制)

AT8952有6个中断源2个中断优先级,lE寄存器控制各中断位lP寄存器中6个中断源的每一个可定为2个优先级。

80H-FFH128个字节与特殊功能寄存器(SFR)地址是重叠的也就是高128字竹的RAM和殊功能寄存器的地址是相同的,但物理它们是分开的

当一条指令访问7FH以上的内部地址单元时,指囹中使用的寻址方式是不同的也即寻址方式决定是访问高128字节RAM还是访问特殊功能寄存器。如果指令是直接寻址方式则为访问特殊功能寄存器.

间接寻址指令访问高128字节RAM 例如下面的间接子址指令中,R0的内容为OAOH 则访问数据字节地址为0A0H

堆栈操作也是间接寻址方式,所以高128位数据RAM亦可作为堆栈区使用。

由于外部时钟信号是通过一个2分频触发器后作为内部时钟信号的所以对外部时钟信号的占空比没有特殊要求,但最小高电平持续时间和最大的低电平持续时间应符合产品技术条件的要求.

at8952引脚图-引脚功能图-管脚图-单片机


AT8952
的定时器O和定时器1的工莋方式与AT8951相同

定时2定时器2是一个16位定时计数器。它既可当定时器使用也可作为外部事件计数器使用,其工作方式由特殊功能寄存器T2ON(洳表3 )的/T2位选择定时器2有三种作方式:捕获方式,自动重装载(向上或向下计数)方式和波特率发生器方式工作方式由T2ON的控制位来選择,参见表4

定时器2由两个8位寄存器TH2TL2组成,在定时器工作方式中每个机器周期TL2寄存器的值加1 ,由于一个机器周期由12个振荡时钟构成因此,计数速率为振荡频率的1/l2
 
在计数工作方式时,当T2引脚上外部输入信号产生由1至O的下降沿时寄存器的值加1,在这种工作方式下烸个机器周期的5SP2期间,对外部输入进行采样若在第一个机器周期中采到的值为1,而在下一个机器周期中采到的值为0 , 则在紧跟着的下一个周期的S3P1期间寄存器加l 由于识别10的跳变需要2个机器周期(24个振荡周期),因此最高计数速率为振荡频率的1/24 .为确保采样的正确性,要求输入的电平在变化前至少保持一个完整周期的时间以保证输入信号至少被采样一次.

捕获方式在捕获方式下,通过T2ON控制位以EXEN2来选抒兩种方式如果ExEN2=0,定时器2是一个16位定时器或计数器计数溢出时,对T2ON溢出标志TFZ置位同到激活中断。如果EXEN2=1定时器2完成相同的操作,而当T2EX引脚外部输入信号发生l至0负跳变时也出现TH2TL2中的值分别被捕获到RAP2HRAP2L中.另外,T2EX引脚信号的跳变使得T2ON中的EXF2置位与TF2相仿,EXF2也会激活中断捕获方式如图4

自动重装载(向上或向下计数器)方式:当定时器2工作于16位自动重装载方式时,能对其编程为向上或向下计数方式这个功能可通过特殊功能寄存器T2ON(见表5)的DEN位(允许向下计数)来选择的。复位时DEN位置“0 " ,定时器2默认设置为向上计数当DEN置位时,定时器2既鈳向上计数也可向下计数这取决于T2EX引脚的值,参见图5DEN=0时,定时器2自动设置为向上计数在这种方式下,T2ON中的EXEN2控制位有两种选择若EXEN2,定时器2为向上计数至OFFFFH溢出置位TF2激活中断,同时把16位计数寄存器RAP2HRAP2L重装载RAP2HRAP2L的值可由软件预置。若EXEN2=1 定时器216位重装载由溢出或外部輸入端T2EX从1至0的下降沿触发。这个脉冲使EXF2置位如果中断允许,同样产生中断

 DEN=1时,允许定时器2向上或向下计数如图6所示。这种方式下T2EX引脚控制计数器方向。T2EX以引脚为逻辑“1”时.定时器向上计数当计数OFFFFH向上溢出时,置位TF2同时把16位计数寄存器RAP2HRAP2L 重装载到TH2TL2中。T2EX引脚為逻辑“0”时定时器2向下计数.当TH2TL2中的数值等于RAP2HRAP2L中的值时,计数溢出置位TF2,司时将OFFFFH数值重新装入定时寄存器中。当定时了计数器2向仩滋出或向下溢出时置位ExF2位.

特率发生器:T2ON创(表3)中的TLK以和RLK置位时,定时/计数器2作为波特率发生器使用如果定时/计数器2作为发送器或接收器.其发送和接收的波特率可以是不同的,定时器1用于其它功能如图7所示。若RLKTLK置位则定时器2工作于波特率发生器方式。

 波特率发生器的方式与自动重装载方式相仿在此方式下,TH2翻转使定时器2的寄存器用RAP2HRAP2L中的16位数值重新装载该数值由软件设置。

定时器既能工作于定时方式也能作于计数方式在大多数的应用中,是工作在定时方式(/T2=0 ) .定时器2作为波特率发生器时与作为定时器的操作昰不同的,通常作为定时器时在每个机器周期(1/12 振荡频率)寄存器的值加1, 而作为波特率发生器使用时,在每个状态时间(1/2 振荡频率)寄存器的值加1 波特率的计算公式如下:

定时器2作为波特率发生器使用的电路如图7所示。T2ON中的RLKTLK=1时波特率工作方式才有效。在波特率发生器工作方式中TH2翻转不能使TF2置位,故而不产生中断:但若EXEN2 置位且T2EX 端产生由l至0的负跳变,则会使ExF2置位此时并不能将(RAP2H, RAP2L)的内容重新装入TH2TL2中。所以当定时器2作为波特率发生器使用时T2EX可作为附加的外部中断源来使用。需要注意的是定时器2 工作于波特频率器时,作为定时器運行(TR2=1)时并不能访问TH2和TL2 。因为此时每个状态时间定时器都会加1对其读写将得到一个不确定的数值。然而对RAP2则可读而不可写,因为寫入操作将是重新装载写入操作可能令写和/或重装载出错.在访问定时器2RAP2寄存器之前,应将定时器关闭(清除TR2

可编程时钟输出:萣时器2可通过编程从P1.0 输出一个占空比为50%的时钟信号,如图8 所示.P1.0引脚除了是一个标准的I/O口外还可以通过编程使其作为定时/计数器2的外部時钟输入和输出占空比50%的时钟脉冲,当时钟振荡频率为16MHz时,输出时钟频率范围为6lH-4MHz

T2OE(T2MOD.1)=1,必须由TR2(T2ON.2)启动或停止定时器时钟输出频率取决於振荡频率和定时器2捕获寄存器(RAP2H, RAP2L)的重新装载值,公式如下:

 在时钟输出方式下定时器2的翻转不会产生中断,这个特性与作为波特率發生器使用时相仿定时器2作为波恃率发生器使用时,还可作为时钟发生器使用但需要注意的是波特率和时钟输出频率不能分开确定,這是因为它们同使用RAP2LRAP2L

8 定时器2时钟输出方式

3个定时器中断(定时器0、l2)和串行口中断所有这些中断源如图9所示。这些中断源可通过汾别设置专用寄存器IE的置位或清0来控制每一个中断的允许或禁止IE也有一个总禁止位EA , 它能控制所有中断的允许或禁止。

注意表5中的IE.6为保留位在AT8951IE.5也是保留位,程序员不应将“l”写入这些位它们是将来AT89系列产品作为扩展用的.定时器2的中断是由T2IN中的TF2EXF2逻辑或产生的.当转姠中断服务程序时,这些标志位不能被硬件清除事实上,服务程序需确定是TF2EXF2产生中断而由软件清除中断标志位.
定时器0和定时器1的標志位TF0TFI在定时器溢出那个机器周期的S5PZ状态置位,而会在下一个机器周期才查询到该中断标志然而,定时器2的标志位TF2在定时器溢出的那個机器周期的S2P2 状态置位并在同一个机器周期内查询到该标志。

AT8952中有一个用于构成内部振荡器的高增益反相放大器引脚XTAL1XTAL2分别是该放大器的输入端和输出端。这个放大器与作为反馈元件的片外石英晶体或陶瓷诺振器一起构成自激振荡器振荡电路参见图10。

外接石英晶体(戓陶瓷诺振器)及电容12接在放大器的反馈回路中构成并联振荡电路对外接电容12虽然没有十分严格的要求,但电容容量的大小会轻微影响振荡频率的高低、振荡器不作的稳定性、起振的难易程序及温度稳定性如果使用石英晶体,我们推荐电容使用30PF1OPF而如使用陶瓷诺振器建议选择4PF10PF用户也可以采用外部时钟采用外部时钟的电路如图10右图所示。这种情况下外部时钟脉冲接到XTAL1端,即内部时钟发生器嘚输入端XTAL2则悬空。

空闲节电棋式:在空闲工作模式状态PU自身处于睡眠状态而所有片内的外设仍保持激活状态,这种方式由软件产生此时,同时将片内RAM和所有特殊功能寄存器的内容冻结.空闲模式可由任何允许的中断请求或硬件复位终止由硬件复位终止空闲状态只需兩个机器周期有效复位信号,在此状态下片内硬件禁止访问内部RAM,但可以访问端口引脚当用复位终止空闲方式时,为避免可能对端口產生意外写入激活空闲模式的那条指令后一条指令不应是一条对端口或外部存储器的写入指令。

掉电棋式:在掉电模式下振荡器停止作,进入掉电模式的指令是最后一条被执行的指令片内RAM和特殊功能寄存器的内容在终止掉电模式前被冻结。退出掉电模式的唯一方法昰硬件复位复位后将重新定义全部特殊功能寄存器,但不改变RAM 中的内容在V恢复到正常作电平前,复位应无效且必须保持一定时间鉯使振荡器重启动并稳定作。空闲和掉电模式下各端口引脚状态如表6所示.

6 空闲和掉电模式外部引脚状态

 AT8952有3个程序加密位,可对芯爿上的3个加密位LBI 、LBZ 、LB3 进行编程(P)或不编程(U)来得到如表7 所示的功能:

U:表示未编程 P:表示编程

    当加密位LB1被编程时在复位期间,以端嘚逻辑电平被采样并锁存.如果单片机卜电后一直没有复位则锁存起的初始值是一个随机数,且这个随机数会一直保存到真正复位为止为使单片机能正常工作,被锁存的EA电平值必须与该引脚当前的逻辑电平一致此外,加密位只有翻由过整片擦除的方法清除

FLASH存储器的編程:
AT8952单片机内部有8k字节的FlASH PEROM,这个FLASH存储阵列出厂时己处于擦除状态(即所有存储单元的内容均为FFH) 用户随时可对其进行编程.编程接口可接收高电压(+12V)或低电压(V)的允许编程信号。低电帐编程模式适合于用户在线编程系统而高电汗编程模式可与通用EPROM编程器兼容。
AT8952单片機中有些属于低电帐编程方式,而有些则是高电片编程方式用户可从芯片上的型号和读取芯片内的签名字节获得该信息,见表8

8 顶媔标记及签名字节

 AT8952的程序存储器阵列是采用字节写入方式编程的,每次写入一个字节要对整个芯片内的PEROM程序存储器写入一个非空字节,必须使用片擦除的方式将整个存储器的内容清除.
 编程前须按表9和图11所示设置好地址、数据及控制信号,AT8952编程方法如下:
 1 .在地址线上加上要编程单元的地址信号
 2 .在数据线上加上要写入的数据字节。
 3 .激活相应的控制信号
 4 .在高电什编程方式时,将EA/Vpp 端加上十12V 编程电壓
 5 .每对FLASH存储阵列写入一个字节或每写入一个程序加密位,加上一个ALE/PROG编程脉冲每个字竹写入周期是自身定时的,通常约为1.5ms.重复1-5步骤.妀变编程单元的地址和写入的数据直到全部文件编程结束.

AT8952单片机用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",这步骤需再编程之前进行
读片内签名字节:AT8952单片机内有3个签名字节,地址为030H 、03lH 和032H 用于声明该器件的厂商、型号囷编程电帐。读AT8952签名字节需将P3.6 和P3.7置逻辑低电平读签名字竹的过程和单元030H、031H及032H 的正常校验相仿,只返回值意义如下:

建立地址到PROG变低时间

PROG變低后地址保持时间

建立数据到PROG变低时间

PROG变低后数据保持时间

地址有效到ALE变低时间

ALE变低后地址保持时间

ALE变低到指令输入有效

PSEN变低到指令输叺有效

PSEN建立后指令保持时间

PSEN建立后指令浮空时间

PSEN建立后到地址有效时间

建立地址到指令输入有效

PSEN变低到地址浮空时间

RD变低到数据输入有效

RD建立后数据保持时间

RD建立后数据浮空时间

ALE变低到数据输入有效时间

地址建立到数据输入有效时间

ALE变低到RDER变低时间

地址建立到RDWR变低时间

數据有效到WR转换时间

数据有效到WR变高时间

WR建立后到数据保持时间

RD变低到地址浮空时间

RDWR变高到ALE变高时间

44引脚薄型塑料四方扁平 (TQFP)


点击文档标签更多精品内容等伱发现~

  文档均来自网络,如有侵权请联系我删除文档


VIP专享文档是百度文库认证用户/机构上传的专业性文档,文库VIP用户或购买VIP专享文档下载特權礼包的其他会员用户可用VIP专享文档下载特权免费下载VIP专享文档只要带有以下“VIP专享文档”标识的文档便是该类文档。

VIP免费文档是特定嘚一类共享文档会员用户可以免费随意获取,非会员用户需要消耗下载券/积分获取只要带有以下“VIP免费文档”标识的文档便是该类文檔。

VIP专享8折文档是特定的一类付费文档会员用户可以通过设定价的8折获取,非会员用户需要原价获取只要带有以下“VIP专享8折优惠”标識的文档便是该类文档。

付费文档是百度文库认证用户/机构上传的专业性文档需要文库用户支付人民币获取,具体价格由上传人自由设萣只要带有以下“付费文档”标识的文档便是该类文档。

共享文档是百度文库用户免费上传的可与其他用户免费共享的文档具体共享方式由上传人自由设定。只要带有以下“共享文档”标识的文档便是该类文档

还剩5页未读, 继续阅读

我要回帖

更多关于 AT和CⅤT哪种变速箱好 的文章

 

随机推荐