片机原理及其接口技术第3章.ppt
《片机原理及其接口技术第3章.ppt》由会员分享,可在线阅读,更多相关《片机原理及其接口技术第3章.ppt(85页珍藏版)》请在三一办公上搜索。
1、第3章 MCS-51单片机的内部资源及应用,主要内容:MCS-51单片机内部各器件的具体结构、组成原理、工作方式的设置及典型应用,为读者后续学习单片机应用系统设计、充分利用单片机内部资源解决工程实际问题奠定基础。重点在于各器件工作方式的设置及灵活应用,难点在于中断系统和定时器/计数器的应用。,3.1.1 MCS-51内部并行I/O口 8051有4个8位并行I/O口,分别命名为P0,P1,P2和P3口。1P0口 P0口为双向三态输入/输出口,P0口既可作为地址/数据总线口,又可作为通用I/O口,可驱动8个TTL输入。在访问,3.1 MCS-51单片机的并行I/O口,外部存储器时,P0口作地址/数
2、据总线复用口,是一个真正的双向口,并分时送出地址的低8位和送出(或接收)相应存储单元的数据。作通用I/O口时,P0口只是一个准双向口,需要在外部引脚处外接上拉电阻。P0口的位结构如右图所示。,2P2口,P2口常用做外部存储器的高8位地址口。当不用做地址口时,P2口也可作为通用I/O口,这时它也是一个准双向I/O口。不必外接上拉电阻就可以驱动任何MOS驱动电路,且只能驱动4个TTL输入。P2口的位结构如右图所示。,3P1口 P1口常用做通用I/O口,它也是一个标准的准双向I/O口,不必外接上拉电阻就可以驱动任何MOS驱动电路,且只能驱动4个TTL输入。P1口的位结构如右图所示。,4P3口 P3口
3、是一个双功能口,第一功能与P1口一样可用做通用I/O口,也是一个准双向I/O口,能驱动4个TTL输入。另外还具有第二功能。P3口工作在第二功能时各管脚定义如下表所示。P3口的位结构图如右图所示。,3.1.2 MCS-51内部并行I/O口的应用,MCS-51I/O端口的操作方式:(1)输出数据方式:CPU通过一条数据传送指令就可以把输出数据写入P0P3的端口锁存器,然后通过输出驱动器送到端口引脚线。例如,下面的指令均可在P0口输出数据。MOV P0,A ANL P0,#data ORL P0,A(2)读端口数据方式:CPU读入的这个数据并非端口引脚线上的数据。读端口数据可以直接读端口。例如,下面
4、的指令均可以从P1口输入数据。MOV A,P1 MOV 20H,P1 MOV R0,P1 MOV R0,P1,(3)读端口引脚方式:读端口引脚方式可以从端口引脚上读入信息。在这种方式下,CPU首先必须使欲读端口引脚所对应的锁存器置1,然后才能读端口引脚。因此,用户在读引脚时必须先置位锁存器后读,连续使用两条指令。例如,下面的程序可以读P1引脚上的低4位信号。MOV P1,#0FH;置位P1引脚的低4位锁存器 MOV A,P1;读P1引脚上的低4位信号送累加器A,在I/O口直接用做输入/输出时,CPU既可以把它们看做数据口,也可以看做状态口,这是由用户决定的。例题1要求将两个BCD拨码开关的数字
5、和,在LED数码管上显示出来。(用CD4511驱动LED)解:CD4511是BCD锁存段码译码共阴LED驱动集成电路,其引脚如右图所示,各引脚功能如下:VCC:接正电源;Vss:接地;A,B,C,D:BCD码输入脚(A为最低位,D为最高位);QaQg:段码输出脚,高电平有效,最大可输出25mA电流;BI:熄灭,接低电平则QaQg全部输出低电平;LT:点亮测试,接低电平则QaQg全部输出高电平;LE:锁存允许,接高电平锁存,则输出不会随BCD码输入改变。,1I/O口直接用于输入/输出,硬件电路设计:BCD拨码开关为4位,两个BCD拨码开关分别接至P3口的高四位和低四位(注意:应连接上拉电阻),由
6、P1口的高四位和低四位通过两片CD4511分别扩展两位LED。硬件电路如下图所示。,软件设计思想:读P3口引脚,得到输入数据,将数据分成2个4位BCD码,求BCD码和,输出到P1口,通过CD4511驱动LED显示。程序如下:ORG 0100H MOV P3,#0FFH;读引脚先对其写1 MOV A,P3;读引脚 CPL A;取反,取真正的键值 MOV 20H,A;A中的数据送20H单元保存 SWAP A;A中的内容半字节交换 ANL A,#0FH;A中得到原高4位的反码 ANL 20H,#0FH;20H单元中得到原低4位的反码 ADD A,20H;A中为原高低4位反码之和 DA A;BCD码调
7、整 MOV P1,A;输出到P1口 SJMP$;程序执行完,“原地踏步”END,2I/O口扩展外部锁存器,为了提高数据传输速率,MCS-51单片机常常需要使I/O口通过外部锁存器和输入设备相连。如下图所示为8051通过74LS373与输入设备连接的接口图。通过中断方式读取数据,8051响应该中断请求后在中断服务程序中通过下面的指令读取输入数据:MOV DPTR,#7FFFH;DPTR指向74LS373端口,地址为7FFFH)MOVX A,DPTR;读入数据到A中,3.2 MCS-51单片机的中断系统,计算机与外界的联系是通过外部设备(也称为外设、输入/输出设备或I/O设备)与外界联系的。计算机
8、与外设之间不是直接相连的,而是通过不同的接口电路来达到彼此间的信息传送的目的。计算机与外设之间交换信息的方式:(1)无条件传送方式:外设对计算机来说总是准备好的。(2)查询传送方式:传送前计算机先查询外设的状态,若已经准备好就传送,否则就继续查询/等待。(3)中断传送方式:外设通过申请中断的方式与计算机进行数据传送。(4)直接存储器存取方式(DMA):传送数据的双方直接通过总线传送数据,不经CPU中转。,3.2.1 中断的基本概念,1中断的定义 所谓“中断”,是指CPU执行正常程序时,系统中出现特殊请求,CPU暂时中止当前的程序,转去处理更紧急的事件(执行中断服务程序),处理完毕(中断服务完成
9、)后,CPU自动返回原程序的过程。作用:采用中断技术可以提高CPU效率、解决速度矛盾、实现并行工作、分时操作、实时处理、故障处理、应付突发事件,可使多项任务共享一个资源(CPU)。中断与子程序的最主要区别:子程序是预先安排好的,中断是随机发生的。中断涉及的几个环节:中断源、中断申请、开放中断、保护现场、中断服务、恢复现场、中断返回。,2.中断源 中断源是指引起中断的设备或事件,或发出中断请求的源头。3.中断的分类 中断按功能通常可分为可屏蔽中断、非屏蔽中断和软件中断三类。可屏蔽中断是指CPU可以通过指令来允许或屏蔽中断的请求。非屏蔽中断是指CPU对中断请求是不可屏蔽的,一旦出现,CPU必须响应
10、。软件中断则是指通过相应的中断指令使CPU响应中断。4.中断优先权与中断嵌套 中断优先级(也称为中断优先权):给每个中断源指定中断响应的优先级别,CPU按中断源的优先级高低顺序响应各中断源发出的中断请求。中断嵌套:在某一瞬间,CPU因响应某一中断源的中断请求而正在执行它的中断服务程序时,若又有一级别高的中断源向CPU发出中断请求,且CPU的中断是开放的,CPU可以把正在执行的中断服务程序暂停下来,转而响应和处理优先权更高的中断源的中断请求,等处理完后再转回来,继续执行原来的中断服务程序,这就是中断嵌套。中断嵌套的过程和子程序嵌套过程类似,子程序的返回指令是RET,而中断服务程序的返回指令是RE
11、TI。,5.中断响应及处理过程 保护断点 寻找中断源 中断处理 中断返回保护断点和寻找中断源都是由硬件自动完成的,用户不用考虑。6.中断系统的功能中断系统:能够实现中断功能的硬件电路和软件程序。中断系统的功能:能够实现中断优先权排队、中断嵌套、自动响应中断和中断返回等功能。MCS-51单片机的大部分中断电路都是集成在芯片内部的,只有外部中断请求信号产生电路才分散在各中断源电路和接口电路中。,3.2.2 MCS-51的中断系统,MCS-51提供了5个中断源,2个中断优先级控制,可实现2个中断服务嵌套。可通过程序设置中断的允许或屏蔽,设置中断的优先级。1MCS-51的中断源 8051允许5个中断源
12、:(1)外部中断源(中断标志为IE0和IE1)由(P3.2)端口线引入,低电平或下降沿引起。由(P3.3)端口线引入,低电平或下降沿引起。(2)内部中断源(中断标志为TF0、TF1和TI/RI)T0:定时/计数器0中断,由T0回零溢出引起。T1:定时/计数器1中断,由T1回零溢出引起。TI/RI:串行I/O中断,完成一帧字符发送/接收引起。,8051的中断结构如下图所示。,CPU识别中断申请的依据:CPU在每个机器周期的S5P2期间,会自动查询各个中断申请标志位,若查到某标志位被置位,将启动中断机制。2中断控制 MCS-51单片机设置了4个专用寄存器用于中断控制,用户通过设置其状态来管理中断系
13、统。(1)定时器控制寄存器TCON(88H),TF1 TR1 TF0 TR0 IE1 IT1 IE0 IT0,TF0/TF1:定时器溢出中断申请标志位(由硬件自动置位)。=0:定时器未溢出;=1:定时器溢出(由全“1”变成全“0”)时由硬件自动置位,申请中断,中断被CPU响应后由硬件自动清零。,TR0/TR1:定时器运行启停控制位(可由用户通过软件设置)。=0:定时器停止运行;=1:定时器启动运行。IE0/IE1:外部中断申请标志位(由硬件自动置位,中断响应后转向中断服务程序时,由硬件自动清0)。=0:没有外部中断申请;=1:有外部中断申请。IT0/IT1:外部中断请求的触发方式控制位(可由用
14、户通过软件设置)。=0:在INT0/INT1端申请中断的信号低电平有效;=1:在INT0/INT1端申请中断的信号负跳变有效。,(2)串行口控制寄存器SCON(98H),TI/RI:串行口发送/接收中断申请标志位(由硬件自动置位,必须由用户在中断服务程序中用软件清0)。=0:没有串行口发送/接收中断申请;=1:有串行口发送/接收中断申请。SCON的高6位用于串行口工作方式设置和串行口发送/接收控制。(3)中断允许控制寄存器IE(0A8H),SM0 SM1 SM2 REN TB8 RB8 TI RI,(3)中断允许控制寄存器IE(0A8H),EA ES ET1 EX1 ET0 EX0,EX0/E
15、X1/ET1/ET0/ES 位:分别是/,T0/T1,串行口的中断允许控制位。=0:禁止中断;=1:允许中断。EA:总的中断允许控制位(总开关):=0:禁止全部中断;=1:允许中断。,(4)中断优先级控制寄存器IP(0B8H),8051有两个中断优先级,即高优先级和低优先级,每个中断源都可设置为高或低中断优先级,以便CPU对所有的中断实现两级中断嵌套。8051内部中断系统对各中断源的中断优先级有一个统一的规定,称为自然优先级(也称为系统缺省优先级)。如下表所示。,8051单片机的中断优先级采用了自然优先级和人工设置高、低优先级的策略,中断处于同一级别时,就由自然优先级确定。开机时,每个中断都处
16、于低优先级,中断优先级可以通过程序来设定,由中断优先级寄存器IP来统一管理。,(4)中断优先级控制寄存器IP(0B8H),PS PT1 PX1 PT0 PX0,PX0/PX1:/优先级控制位:=0:属低优先级;=1:属高优先级。PT0/PT1:T0/T1中断优先级控制位:=0:属低优先级;=1:属高优先级。PS1:串行口中断优先级控制位:=0:属低优先级;=1:属高优先级。,中断优先级处理原则:对同时发生多个中断申请时:不同优先级的中断同时申请:先高后低 相同优先级的中断同时申请:按序执行 正处理低优先级中断又接到高级别中断:高打断低 正处理高优先级中断又接到低级别中断:高不理低,3中断响应,
17、(1)中断响应的条件 MCS-51单片机工作时,在每个机器周期中都会去查询各个中断标志,如果有中断请求。必须满足下列条件单片机才能响应中断。相应的中断是开放的;没有同级的中断或更高级别的中断正在处理;正在执行的指令必须执行完最后 1个机器周期;若正在执行RETI,或正在访问IE或IP寄存器,则必须执行完当前指令的下一条指令。后方能响应中断。,(2)中断响应的过程,中断过程包括中断请求、中断响应、中断服务、中断返回四个阶段。中断请求:中断源将相应请求中断的标志位置“1”,表示发出请求,并由CPU 查询。中断响应:在中断允许条件下相应中断。断点入栈撤除中断标志关闭低同级中断允许中断入口地址送PC。
18、这些工作都是由硬件自动完成的。中断服务:根据入口地址转中断服务程序,包含保护现场、执行中断主体、恢复现场。中断返回:执行中断返回RETI指令断点出栈开放中断允许返回原程序。,中断服务程序入口地址:中断响应的主要内容就是由硬件自动生成一条长调用指令(LCALL addr16),CPU执行这条长调用指令便响应中断,转入相应的中断服务程序。这里的addr16就是程序存储器中相应的中断服务程序的入口地址,MCS-51的5个中断源的中断服务程序入口地址是固定的,如下表所示。,8051的5个中断源的中断服务入口地址之间相差8个单元。这8个存储单元用来存储中断服务程序一般来说是不够的。用户常在中断服务程序地
19、址入口处放一条三字节的长转移指令。一般地,主程序从0030H单元以后开始存放。例如:ORG 0000HLJMP START;转入主程序,START为主程序地址标号ORG 0003HLJMP INT0;转外中断中断服务程序ORG 000BHLJMP T0;转定时器T0中断服务程序ORG 0030HSTART:;主程序开始(3)中断响应时间 正常中断响应时间至少为38个机器周期,如果有同级或高级中断服务,将延长中断响应时间。,4中断请求的撤除,为了避免中断请求标志没有及时撤除而造成的重复响应同一中断请求的错误,CPU在相应中断时必须及时将其中断请求标志位撤除。8051的5个中断源的中断请求撤除的方
20、法是不同的。(1)定时器溢出中断请求的撤除 定时器溢出中断得到响应后,其中断请求的标志位TF0和TF1由硬件自动复位。(2)串行口中断请求的撤除 串行口中断得到响应后,其中断请求的标志位TI和RI不能由硬件自动复位,必须由用户在中断服务程序的适当位置通过如下指令将它们撤除。CLR TI;撤除发送中断请求标志 CLR RI;撤除接收中断请求标志 或采用字节型指令:ANL SCON,#0FCH,(3)外部中断请求的撤除,外部中断请求的两种触发方式(电平触发和负边沿触发)的中断请求撤除的方法是不同的。负边沿触发方式:CPU在前一机器周期采到/引脚为高,后一机器周期采到为低才认为是一次中断请求,即依靠
21、CPU两次检测(或)上的负边沿触发电平状态而置位外部中断标志位IE0或IE1。CPU 可记忆申请、可由硬件自动撤除中断申请。电平触发方式:/引脚上的低电平须持续到中断发生。若中断返回前仍未及时撤除低电平,虽然CPU在响应中断时能由硬件自动复位IE0或IE1,但引脚上的低电平仍会使已经复位的IE0或IE1再次置位,产生重复中断的错误。,电平触发型外部中断请求的撤除必须由外部硬件使(或)上的低电平随着其中断被响应而变为高电平。其中断请求撤除的电路如下图所示。,外来的低电平反相CP端产生上跳沿 D端的“0”输出到Q端申请中断,中断服务返回前对P1.0送“0”令Q端变为“1”指令如下:ANL P1,#
22、0FEH(或CLR P1.0);令Q端置“1”ORL P1,#01H(SETB P1.0);令SD端置“1”,以免下次中断来时Q端不能变“0”,3.2.3 MCS-51中断系统的编程,(1)中断初始化设置:开相应中断允许(IE)、根据需要选择优先级(IP)和选择外中断触发方式(TCON),设置计数器、串行口的有关参数。(2)中断服务程序的编写:中断入口、保护现场、关中断、中断服务主体程序、恢复现场、开中断、设置计数器、串行口的有关参数、中断返回指令RETI。例题2 设8051外部中断源接引脚,中断触发方式为电平触发,试编制8051中断系统的初始化程序。解:采用位操作指令实现(也可以采用传送指令
23、和逻辑指令)。SETB EA;开总中断 SETB EX0;开中断 SETB PX0;设置为高优先级 CLR IT0;设置为电平触发方式,例题3 通过外部中断控制八盏灯循环点亮。解:通过P1口扩展八盏灯,在 引脚接一个按钮开关到地,每按一下按钮就申请一次中断,点亮一盏灯,中断服务则是:依次点亮八盏灯中的一盏。采用边沿触发。硬件电路如下图所示。,程序如下:ORG 0000H LJMP MAIN ORG 0013H;中断服务程序入口地址 LJMP IN11 MAIN:SETB EA;开总中断允许“开关”SETB EX1;开分中断允许“开关”CLR PX1;低 优先级(也可不要此句)SETB IT1;
24、边沿触发 MOV A,#01H;给累加器A赋初值 SJMP$;原地等待中断申请 IN11:RL A;左环移一次 MOV P1,A;输出到P1口 RETI;中断返回 END,3.2.4 MCS-51扩展外部中断请求输入口,8051单片机只提供了两个外部中断请求输入端,如果需要使用多于两个的中断源,就必须扩展外部中断请求输入口。1定时器/计数器用于扩展外部中断请求输入口 8051单片机有两个定时器/计数器,它们作为计数器使用时,计数输入端T0(或T1)发生负跳变将使计数器加1,利用此特性,适当设置计数初值,就可以把计数输入端T0(或T1)作为外部中断请求输入口。其特点是以占用内部定时中断为代价的。
25、中断服务程序的入口地址仍然为000BH或001BH。,2查询方式扩展外部中断请求输入口 把多个中断源通过硬件(如与非门)引入外部中断输入端,同时又连到某个I/O口。当有中断源申请中断时,在中断服务程序中通过软件查询可确定哪一个是正在申请的中断源,其查询的次序可由中断优先级决定。其特点是中断响应速度较慢。适用于外部中断源较多的场合。3使用专用芯片扩展外部中断请求输入口 当外部中断源较多,同时又要求中断响应速度很高时,查询方式扩展外部中断请求输入口的方法很难满足要求。这时可以使用专用接口芯片进行外部中断请求输入口的扩展。74LS148优先级编码器和可编程中断控制器8259均可以实现该任务。,3.3
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 原理 及其 接口 技术
链接地址:https://www.31ppt.com/p-6426481.html