技术文档

AT89S51单片机 AT89S51 单片机简介及主要功能详细列举

小编 2024-11-24 技术文档 23 0

AT89S51 单片机简介及主要功能详细列举

首先,引以为傲的AT89S51微控制器备受瞩目。此乃ATMEL公司匠心之作,拥有电气编程及清零特性、并且与广为使用的8051单片机完美整合。此芯片具备的最高存储容量为4KB的程序码,对我们日常所见的中小规模电子产品而言,意义非凡。

4KB存储空间虽较小,但对诸如手机、电脑等日常高频电子设备而言,其重要性不容忽视。借助于精巧芯片技术,现代科技及生活方式正发生着深远变革。

重置引脚的神奇作用

在AT89S51诸多核心功能中,复位引脚的作用不容忽视。其功能仅限于接收高电平信号,且一旦接收到,便会将其电位提升到高位,并持续最少两个机器周期,从而使AT89S51能够自动进行系统复位。这项设计展现出极高的技术含量以及独特的吸引力。

程序重置是全面性的过程,涵盖了将特定内核功能寄存器复位至默认值以及从内存首址(即0000H)重新加载程序代码等环节。无论遇到何种状况,AT89S51都能迅速恢复到初始状态,从而保障程序的稳定运行。

"EA"引脚的秘密

在该文中,我们将详细探讨名为"EA"的神秘引脚。此引脚专为机器执行外部程序逻辑而设,采用低电平触发机制,只有当电压降低到极低程度时,才会引发对外置程序代码的调用。特别地,对于8031和8032芯片来说,由于它们内部没有独立的程序存储区域,因此这个功能显得尤为关键。

当应用型号为8751的内置程序区域时,相应地应设定接口为有效高电平模式。且在此种情况下,接口还能实现21V高压(Vpp)的写入操作。如此设计,是否让人不禁联想到对芯片进行高级SPA护理的可能性呢?

ALE引脚的多功能性

ALE(地址锁存允许)端点的主要作用为产生接近系统运行频率约六分之一的信号,用以触发和控制各种外设电路的晶体管启动和关闭;在8751芯片程序写入环节,ALE端点还作为特殊编程功能予以利用。

通过这一引脚,AT89S51能有效地控制外部八位锁存器(例如74LS373),使端口0的地址总线(A0至A7)被锁定在其中。由于其并行传输模式可以同时传送地址和数据,因此该引脚的潜力无法估量。

PSEN及RD引脚的强大功能

本款器件配备关键技术PSEN和RD,具备外部扩展内存及EPROM启动功能,可将程序与数据区域纳入64K共享地址空间,显著提高AT89S51的数据处理性能和程序执行效率,确保设备稳定运行。

此外,其他三个I/O接口—P1、P2和P3亦有各自特色。首先在重载方面,P0的多功能性使其最多能支持8个LSTTL负载;而具备自升压电路的双向I/O接口P2与P1,每个引脚承受4个LSTTL负载,极大提高了AT89S51处理器的可靠性。

P3引脚的特别之处

尤其需关注,P3端口包含P3.6(WR)与P3.7(RD)引脚,在控制并操作外围数据存储的读取与写入过程中扮演关键角色。正是由于这两根引脚所具有的特殊功能,使AT89S51得以高效地进行数据处理与交互,确保整体系统始终保持高速响应与高效运行。

AT89S51芯片看似平淡无奇,实则具备诸多精细和强大功能,在现代科技领域扮演重要角色,极大提升了人类生活品质和丰富程度。

总结与思考

深度分析表明,AT89S51芯片看似普通,却饱含深奥的科技知识与独特技艺。作为现代电子设备核心部件,担当着科技进步的重大责任。尊贵的读者们,您是否同样对这款微型芯片怀有探索之心?是否渴望亲身感受其独特魅力?让我们共同开启这趟科技探索之旅,揭开科技世界的无限可能!

基于51单片机的电子时钟!内附开题报告模板、论文模板

基于单片机的数字式电子时钟设计

设计要求

1)设计AT89S51的最小系统;

2)LED显示电路及与AT89S51接口,LED数码块显示时、分、秒;

3)时钟调整电路及与AT89S51接口;

4)电子时钟程序设计;

5)基于Proteus的电子时钟原理及仿真实现;

6)电子时钟实物制作;

2 总体方案设计

2.1 实现时钟计时的基本方法

利用MCS-51系列单片机的可编程定时/计数器、中断系统来实现时钟计数。

(1) 计数初值计算:

把定时器设为工作方式1,定时时间为50ms,则计数溢出20次即得时钟计时最小单位秒,而100次计数可用软件方法实现。

假设使用T/C0,方式1,50ms定时,fosc=12MHz。

则初值X满足(216-X)×1/12MHz×12μs =50000μs

X=15536→0011110010110000→3CB0H

(2) 采用中断方式进行溢出次数累计,计满20次为秒计时(1秒);

(3) 从秒到分和从分到时的计时是通过累加和数值比较实现。

2.2 电子钟的时间显示

电子钟的时钟时间在六位数码管上进行显示,因此,在内部RAM中设置显示缓冲区共8个单元。

LED8 LED7 LED6 LED5 LED4 LED3 LED2 LED1

37H 36H 35H 34H 33H 32H 31H 30H

时十位 时个位 分隔 分十位 分个位 分隔 秒十位 秒个位

2.3 电子钟的时间调整

电子钟设置3个按键通过程序控制来完成电子钟的时间调整。

reset键复位

hour键调整时;

min键调整分;

2.4 总体方案介绍

2.4.1 计时方案

利用AT89S51单片机内部的定时/计数器进行中断时,配合软件延时实现时、分、秒的计时。

2.4.2 控制方案

AT89S51的P0口和P2口外接由八个LED数码管(LED8~LED1)构成的显示器,用P0口作LED的段码输出口,P2口作八个LED数码管的位控输出线,P1口外接四个按键reset、hour、min构成键盘电路。

3 系统硬件电路设计

根据以上的电子时钟的设计要求可以分为以下的几个硬件电路模块:单片机模块、数码显示模块与按键模块

3.1单片机模块设计

3.1.1 芯片分析

AT89C51单片机引脚图如下:

MCS-51单片机是标准的40引脚双列直插式集成电路芯片,其各引脚功能如下:

VCC:+5V电源。

VSS:接地。

RST:复位信号。当输入的复位信号延续两个机器周期以上的高电平时即为有效,用完成单片机的复位初始化操作。

XTAL1和XTAL2:外接晶体引线端。当使用芯片内部时钟时,此二引线端用于外接石英晶体和微调电容;当使用外部时钟时,用于接外部时钟脉冲信号。

P0口:P0口为一个8位漏极开路双向I/O口,当作输出口使用时,必须接上拉电阻才能有高电平输出;当作输入口使用时,必须先向电路中的锁存器写入“1”,使FET截止,以避免锁存器为“0”状态时对引脚读入的干扰。

P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,它不再需要多路转接电路MUX;因此它作为输出口使用时,无需再外接上拉电阻,当作为输入口使用时,同样也需先向其锁存器写“1”,使输出驱动电路的FET截止。

P2口:P2口电路比P1口电路多了一个多路转接电路MUX,这又正好与P0口一样。P2口可以作为通用的I/O口使用,这时多路转接电路开关倒向锁丰存器Q端。

P3口:P3口特点在于,为适应引脚信号第二功能的需要,增加了第二功能控制逻辑。当作为I/O口使用时,第二功能信号引线应保持高电平,与非门开通,以维持从锁存器到输出端数据输出通路的畅通。当输出第二功能信号时,该位应应置“1”,使与非门对第二功能信号的输出是畅通的,从而实现第二功能信号的输出,具体第二功能如表1所示。

3.1.2 晶振电路

右图所示为时钟电路原理图,在AT89S51芯片内部有一个高增益反相放大器,其输入端为芯片引脚XTAL1,输出端为引脚XTAL2。而在芯片内部,XTAL1和XTAL2之间跨接晶体振荡器和微调电容,从而构成一个稳定的自激振荡器。时钟电路产生的振荡脉冲经过触发器进行二分频之后,才成为单片机的时钟脉冲信号。

3.1.3 复位电路

单片机复位的条件是:必须使RST/VPD 或RST引(9)加上持续两个机器周期(即24个振荡周期)的高电平。例如,若时钟频率为12 MHz,每机器周期为1μs,则只需2μs以上时间的高电平,在RST引脚出现高电平后的第二个机器周期执行复位。单片机常见的复位如图所示。电路为上电复位电路,它是利用电容充电来实现的。在接电瞬间,RESET端的电位与VCC相同,随着充电电流的减少,RESET的电位逐渐下降。只要保证RESET为高电平的时间大于两个机器周期,便能正常复位。该电路除具有上电复位功能外,若要复位,只需按图中的RESET键,此时电源VCC经电阻R1、R2分压,在RESET端产生一个复位高电平。

3.2 数码显示模块设计

系统采用动态显示方式,用P0口来控制LED数码管的段控线,而用P2口来控制其位控线。动态显示通常都是采用动态扫描的方法进行显示,即循环点亮每一个数码管,这样虽然在任何时刻都只有一位数码管被点亮,但由于人眼存在视觉残留效应,只要每位数码管间隔时间足够短,就可以给人以同时显示的感觉。

3.3 按键模块

下图为按键模块电路原理图,reset为复位键,hour为时钟调控键,min为分钟调控键。

4、系统软件设计

4.1 软件设计分析

在编程上,首先进行了初始化,定义程序的的入口地址以及中断的入口地址,在主程序开始定义了一组固定单元用来储存计数的时.分.秒,在显示初值之后,进入主循环。在主程序中,对不同的按键进行扫描,实现秒表,时间调整,复位清零等功能,系统总流程图如下图7:

图 7 系统总体流程图

4.2 源程序清单

ORG 0000H

MOV 30H,#1 设置时钟的起始时间12.00.00,分配显示数据内存

MOV 31H,#2

MOV 32H,#0

MOV 33H,#0

MOV 34H,#0

MOV 35H,#0

MOV TMOD,#01 启动计数器

XS0: SETB TR0 使 TRO位置1

MOV TH0,#00H 计数器置零

MOV TL0,#00H

XS:

MOV 40H,#0FEH 扫描控制字初值

MOV DPTR,#TAB 取段码表地址

MOV P2,40H 从P2口输出

MOV A,30H 取显示数据到A

MOVC A,@A+DPTR 查显示数据对应段码

MOV P0,A 段码放入P0中

LCALL YS1MS 显示1MS

MOV P0,#0FFH PO端口清零

MOV A,40H 取扫描控制字放入A中

RL A A中数据循环左移

MOV 40H,A 放回40H地址段内

MOV P2,40H

MOV A,31H

ADD A,#10 进位显示

MOVC A,@A+DPTR

MOV P0,A

LCALL YS1MS

MOV P0,#0FFH

MOV A,40H

RL A

MOV 40H,A

MOV P2,40H

MOV A,32H

MOVC A,@A+DPTR

MOV P0,A

LCALL YS1MS

MOV P0,#0FFH

MOV A,40H

RL A

MOV 40H,A

MOV P2,40H

MOV A,33H

ADD A,#10

MOVC A,@A+DPTR

MOV P0,A

LCALL YS1MS

MOV P0,#0FFH

MOV A,40H

RL A

MOV 40H,A

MOV P2,40H

MOV A,34H

MOVC A,@A+DPTR

MOV P0,A

LCALL YS1MS

MOV P0,#0FFH

MOV A,40H

RL A

MOV 40H,A

MOV P2,40H

MOV A,35H

MOVC A,@A+DPTR

MOV P0,A

LCALL YS1MS

MOV P0,#0FFH

MOV A,40H

RL A

MOV 40H,A

JB TF0,JIA 如果TF0为1时,则执行JIA,否则顺序执行

JNB P1.0,P100 为0则 转移到P100

JNB P1.1,P1000 为0则 转移到P1000

JNB P1.2,P10000 为0则 转移到P10000

AJMP XS 跳转到 XS

P100: MOV 30H,#0 清零程序

MOV 31H,#0

MOV 32H,#0

MOV 33H,#0

MOV 34H,#0

MOV 35H,#0

JIA: CLR TF0 TF0清零

MOV A,35H 秒单位数据到A

CJNE A,#9,JIA1 与 9进行比较,大于9就转移到JIA1

MOV 35H,0 秒个位清零

MOV A,34H 秒十位数据到A

CJNE A,#5,JIA10 与5进行比较,大于5就转移到JIA10

MOV 34H,#0 秒十位清零

P10000: JNB P1.2,P10000 为0则 转移到P10000

MOV A,33H 取分的个位到A

CJNE A,#9,JIA100 与 9进行比较,大于9就转移到JIA100

MOV 33H,#0 分的个位清零

MOV A,32H 分十位数据到A

CJNE A,#5,JIA1000 与5进行比较,大于5就转移到JIA1000

MOV 32H,#0 分的十位清零

P1000: JNB P1.1,P1000 为0则 转移到P1000

MOV A,31H 时个位数据到A

CJNE A,#9,JIA10000 与 9进行比较,大于9就转移到JIA10000

MOV 31H,#0 时的个位清零

MOV A,30H 时十位数据到A

CJNE A,#2,JIA100000 与2进行比较,大于5就转移到JIA100000

MOV 30H,#0 时的十位清零

AJMP XS0 转移到 XSO

JIA100000:

INC 30H 加1

AJMP XS0 跳转到 XS0

JIA10000:

CJNE A,#3,JIAJIA 与3进行比较,大于则转移到JIAJIA

MOV A,30H 将时的十位放到 A

CJNE A,#02,JIAJIA 与2进行比较,大于则转移到JIAJIA

MOV 30H,#0 时段清零

MOV 31H,#0

AJMP XS0 跳转到XSO

JIAJIA:

INC 31H 加一

AJMP XS0

JIA1000:INC 32H

AJMP XS0

JIA100: INC 33H

AJMP XS0

JIA10: INC 34H

AJMP XS0

JIA1: INC 35H

AJMP XS0

RET 返回

YS1MS: MOV R6,#9H 延时程序

YL1: MOV R7,#19H

DJNZ R7,$

DJNZ R6,YL1

RET

TAB:

DB 0C0H,0F9H,0A4H,0B0H,099H,092H,082H,0F8H,080H,090H 共阳段码表

DB 040H,079H,024H,030H,019H,012H,002H,078H,000H,010H

END

5 系统仿真与实验测试

5.1 系统仿真

运用proteus软件进行仿真现在proteus软件中建立一个新的文件,再根据自己的要求选择所需的器件,把器件进行适当的排位后进行连接,连接后运行软件进行仿真。

5.2 实验测试

电子时钟主要的设计要求是能够实现时钟的一般功能,以及包括时间的调整功能,这个基于单片机的电子时钟基本上实现了上述功能,能够通过时间调整电路对时间进行调整以及复位。

6 心得体会

单片机作为我们主要的专业课程之一,我觉得单片机课程设计很有必要,而且很有意义。但当拿到题目时,确实不知道怎么着手,有些迷茫,上网查资料,问老师,在老师的帮助下,历时两个星期,解决一个又一个的困难,终于完成任务。

在这次课程设计中,运用到了很多以前的专业知识,虽然过去从未独立应用过它们,但在学习的过程中带着问题去学我发现效率很高,这是我做这次课程设计的一大收获。另外,要做好一个课程设计,就必须做到:在设计程序之前,对所用单片机的内部结构有一个系统的了解,知道该单片机内有哪些资源;要有一个清晰的思路和一个完整的的软件流程图;在设计程序时,不能妄想一次就将整个程序设计好,反复修改、不断改进是程序设计的必经之路;要养成注释程序的好习惯,一个程序的完美与否不仅仅是实现功能,而应该让人一看就能明白你的思路,这样也为资料的保存和交流提供了方便;在设计课程过程中遇到问题是很正常德,但我们应该将每次遇到的问题记录下来,并分析清楚,以免下次再碰到同样的问题的课程设计结束了,但是从中学到的知识会让我受益终身。发现、提出、分析、解决问题和实践能力的提高都会受益于我在以后的学习、工作和生活中。设计过程,好比是我们人类成长的历程,常有一些不如意,但毕竟这是第一次做,难免会遇到各种各样的问题。在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固,不能灵活运用。

通过这次设计,我懂得了学习的重要性,了解到理论知识与实践相结合的重要意义,学会了坚持、耐心和努力,这将为自己今后的学习和工作做出了最好的榜样。另外,要非常感谢我的指导老师,是她指引我克服一个由一个的困难,让我学会对困难无所畏惧,以及对问题的一些很重要的思考方法。

我学会对困难无所畏惧,以及对问题的一些很重要的思考方法。

附录

附录1 硬件电路总图

相关问答

80c 51单片机 AT89S 52单片机的区别?

51单片机和52单片机区别:1、种类不同:51系列单片机是指51内核,stc89c5X基本都是51内核的种类。2、大小不同:最后一个数字表示E2prom的大小,E2prom=X*4K,c...

c 51 的数据类型""idata,code,xdata,pdata""各对应 at89s51单片机 的哪些存储空间?

idata对应于内部RAM00H~FFHcode对应于程序存储器的0000H~1FFFH(8K)如果扩展可寻址64K。使用MOVCxdata对应于外部RAM0000H~FFFFH(需要...

89s51单片机 有哪几个中断源?对应的中断入口地址是什么?

AT89S51共有5个中断向量:2个外中断(INT0和INT1),2个定时中断(Timer0和Timer1)和一个串行中断。中断入口地址如下:外部中断INT00003H定时器0...AT89...

AT89S51单片机 内部集成哪些外围功能部件?

1、4kBytesFlash片内程序存储器;2、128bytes的随机存取数据存储器(RAM);3、32个外部双向输入/输出(I/O)口;4、2个中断优先级、2层中断嵌套中断;5......

at89s51单片机 的EA引脚高电平和低电平的区别?

EA=0,程序从片内存储器开始执行。EA=1,程序执行片外存储器程序。EA=0,程序从片内存储器开始执行。EA=1,程序执行片外存储器程序。

AT89S51单片机 寻址范围?

AT89S51单片机是16位计算机,寻址范围0000~0XFFFF。AT89S51单片机是16位计算机,寻址范围0000~0XFFFF。

MC S51单片机 at89 c51单片机是一回事吗?

泻药两者主要的区别在于ROM和RAM的大小不一样。AT89C51RC有32K的FLASH和512字节的RAM,而AT89C51只有8K和256字节。在这类基本51内核上写代码,你可以选择Keil开.....

AT89S51单片机 的内部数据存储器分为哪几个区及其使用特点?

大致可分为三个区域:00H~1FH为四组工作寄存器组(R0~R7),任何时刻单片机只使用其中1组,在中断等服务中指定使用和当前不一样的寄存器组,有利于快速现场保...

at89s51单片机 内部包含哪些主要逻辑功能部件,各部分的功能作用?

1,ALU算术逻辑运算单元;2,ROM或Flash程序存储器;3,RAM数据存储器;4,定时/计数器;5,UART串口通信功能模块;6,时钟脉冲振荡器;7,中断逻辑单元;...5,UAR...

数据总线是位.14、 89 C 51单片机 有个16位可编程定时器/计数...

[最佳回答]13、51系列单片机地址总线是16位,数据总线是8位.14、89C51单片机有2个16位可编程定时器/计数器,有4种工作方式.15、80C51单片机片内ROM的容...

猜你喜欢