微控制器原理及应用全课件4-6章_第1页
微控制器原理及应用全课件4-6章_第2页
微控制器原理及应用全课件4-6章_第3页
微控制器原理及应用全课件4-6章_第4页
微控制器原理及应用全课件4-6章_第5页
已阅读5页,还剩421页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

微控制器

——原理及应用——2第四章80C51系列微控制器的功能单元4.1.1I/O接口概述4.1并行I/O接口I/O接口是CPU和外围设备之间交换信息的连接部件,是CPU与外设之间进行数据传送的桥梁和纽带。外围设备种类繁多,工作速度通常比CPU的速度低很多,且不同外围设备的工作速度、信息类型、传送方式差别很大,因此导致CPU与外设之间的信息传送十分复杂,所以CPU和外设之间必须有接口电路,通过它协调单片机与外设之间的数据传送。3

在单片机应用中,输入设备通过I/O接口电路把程序、数据或现场采集到的各种信息输入单片机,单片机的处理结果和控制信息要通过I/O接口电路传送到输出装置,以便显示、打印或实现各种控制。一般来说I/O接口电路的主要功能如下。地址译码由译码器对地址进行译码,选择外围设备,以便CPU对被寻址的外设进行读/写操作。1.I/O接口的功能42)数据缓冲和锁存

CPU通过总线与多个外设打交道。但是,各输入设备的数据线不能都直接与CPU的数据总线相连,必须经输入缓冲器接到数据总线上;否则,会出现几个输入设备同时占用数据总线,发生“总线冲突”,以致CPU不能正常工作。缓冲电路便于实现在同一时刻CPU只与一个外设交换信息,即只有被选中的外设与CPU交换信息。单片机传送信息的速度一般远远高于外设的工作速度。当单片机向外设输出信息时,外设还来不及立即将信息处理完毕。例如,点阵式打印机打印一个字符约需10ms,而单片5机输出一个字符只需10s左右。因此,在输出接口电路中应设置数据锁存器,以便及时把CPU输出的数据锁存起来,然后再由外设进行处理。3)信息转换外设送往单片机的信息应该转换成单片机所能接收的数字量,而单片机输出的信息应该转换成外设所要求的信号。因此,I/O接口电路应能实现信息的转换。例如,串行、并行数据的互相转换,电压、电流的转换,电平的转换,模/数的转换,数/模的转换等。64)通信联络为了协调CPU与外设之间的信息交换,CPU需要通过I/O接口电路以一定的方式与外设进行通信联络,以保证不丢失信息。为了进行通信联络,I/O接口电路传送的信息除了数据之外,还要提供外设状态信息及CPU对外设的启停控制信号等。72.接口与端口I/O接口的功能主要通过电路实现,因此也称之为接口电路。在接口电路中应该包含数据寄存器以保存输入输出数据,状态寄存器以保存外设的状态信息,命令寄存器以保存来自CPU的有关数据传送的控制命令。由于在数据的传送中,CPU需要对这些寄存器的状态口和保存命令的命令口寻址,因此通常把接口电路中这些已编址并能进行读或写操作的寄存器称为端口(Port),或简称口。因此,一个接口电路就对应着多个端口地址,对它们像存储单元一样进行编址。83.80C51系列微控制器端口

标准80C51系列微控制器共有4个8位的并行双向口,有32根输入/输出(I/O)口线。各口的每一位均由锁存器、输出驱动器和输入缓冲器所组成。因为它们在结构上存在一些差异,所以各口的性质和功能也就有了差异。下面分别介绍P0~P3这4个端口。94.1.2P0口P0口是一个多功能的8位端口,可以字节访问也可以位访问,其字节访问地址为80H,位访问地址为80H~87H。P0口的各位结构完全相同,但相互之间又是独立的。P0口的某一位的位电路结构图如图4-1所示,其中i的取值范围为0~7。101.位电路结构

从图4-1可以看出,P0.i的电路包含以下内容:(1)一个数据输出锁存器,用于输出数据锁存。(2)两个三态缓冲器BUF1、BUF2,分别用于缓冲锁存器数据和引脚数据;(3)一个2选1的数据选择器MUX21,其中一个输入来自锁存器的端,另一个输入为“地址/数据”信号的反相输入,选择控制端为“控制”。(4)数据输出的驱动电路和控制电路,由两个场效应管T1、T2和一个与门组成。122.工作过程分析1)P0口用作“地址/数据”总线

(1)当MUX21的选择控制端置1时,选择“地址/数据”输出到T2,此时P0口输出地址/数据。当MUX21的选择控制端“控制”置1时,“地址/数据”信号控制场效应管T1,而“地址/数据”信号的反相信号控制场效应管T2。当输出的地址/数据信号为1时,与门输出为1,场效应管T1导通,场效应管T2截止,P0.i引脚输出为1;当输出的地址/数据信号为0时,与门输出为0,场效应管T1截止,场效应管T2导通,P0.i引脚输出为0。13通过上述分析可以看出,此时的输出状态随地址/数据线变化;而且,场效应管T1、T2轮流导通,构成了推拉式的输出电路,其负载能力大大增加。场效应管T1起到内部上拉电阻的作用。(2)当MUX21的选择控制端置0时,从P0口输入数据。真正的双向口是具有高电平、低电平和高阻抗3种状态的端口。显然,此时P0口在不输入数据时处于高阻状态,因此,P0口作为地址/数据总线使用时是一个真正的双向端口,简称双向口。142)

P0口用作通用I/O口当系统不进行外部程序存储器和数据存储器扩展时,即不将P0口用作系统的地址/数据总线使用时,P0口可作为通用的I/O口使用。当P0口用作通用I/O口时,MUX21的选择控制端“控制”置0,选择端输出到T2,同时与门输出为0,场效应管T1截止,则P0口的输出电路为漏极开路输出,形成OD门。15(1)P0口输出数据。当P0口输出数据时,来自CPU的“写”脉冲加到锁存器的CLK端,内部总线上的数据写入锁存器,并通过T2输出到P0.i引脚。当锁存器内的数据为1时,则输出端为0,场效应管T2截止,由于输出为漏极开路,此时必须外接上拉电阻才能输出1(高电平)。当锁存器内的数据为0时,场效应管T2导通,P0口输出为0(低电平)。(2)从P0口输入数据。当从P0口输入数据时,有两种读入方式:“读引脚”和“读锁存器”(对应两种从P0口读入数据指令)。16当CPU发出“读引脚”指令时,锁存器的输出必须为1(即端输出为0),从而使场效应管T2截止,引脚的状态经三态缓冲器BUF2进入内部总线;反之,若“读引脚”时锁存器的输出为0(即端输出为1),则场效应管T2导通,从而使得P0.i引脚电平被钳位在0(低电平),使输入值1(高电平)无法读入。此外,在场效应管T2导通的状态下,P0.i引脚的高电平被强行拉回为低电平,从而可能产生很大的输入电流,将场效应管T2烧毁。17当CPU发出“读锁存器”指令时,锁存器内的数据通过Q输出端经由三态缓冲器BUF1进入CPU内部总线。之所以会有“读锁存器”的指令(例如“读-改-写”指令ANLP0,A),是因为“读锁存器”可以避免一些错误的读操作。例如,用P0.i引脚去驱动晶体管的基极。当对端口P0.i写入值1(高电平)时,引脚P0.i为高电平(已外接上拉电阻),则晶体管导通,该引脚被钳位在低电平。若此时CPU立刻去读该引脚的值,则由于晶体管导通,读入CPU的值为0。显然这个值是错误的,因为锁存器输出的值为1。18综上所述,P0口具有以下功能和特点。

(1)作为地址/数据复用总线使用。此时,P0相当于一个真正的双向口,用作与外部存储器的连接,配合P2口,输出16位地址的低8位地址和输入/输出8位数据。当P0口作地址/数据复用总线用之后,就再也不能作I/O口使用了。当然,由于现在生产的多种80C51单片机内部集成了足够的ROM和RAM,所以,P0口很少用作地址/数据复用总线,大部分情况,P0口仅用作通用I/O口。3.P0口的特点19

(2)作为I/O口使用。此时,P0口需要外接上拉电阻,端口只有两个状态:高电平、低电平,是一个准双向口。为了能够从引脚读入正确的数据,当P0口由输出状态转变为输入状态时,应首先向锁存器P0.i写1(执行指令MOVP0,#0FFH)。当单片机复位后,锁存器P0.i被自动置1,可立即作输出口使用。204.1.3P1口P1口只有一个功能:I/O口。对P1口来说,可以字节访问也可以位访问,其字节访问地址为90H,位访问地址为90H~97H。P1口的各位结构完全相同,但相互之间又是独立的。P1口的某一位的位电路结构图如图4-2所示,其中i的取值范围为0~7。211.位电路结构

从图4-2可以看出,P1.i的电路包含以下内容:(1)一个数据输出锁存器,用于输出数据锁存。(2)两个三态缓冲器BUF1、BUF2,分别用于缓冲锁存器数据和引脚数据。(3)数据输出的驱动电路,由一个场效应管T2和一个片内上拉电阻组成。222.工作过程分析P1口只能作为通用I/O口使用。

(1)

P1口用作输出口。CPU输出0时,D=0,=1,场效应管T2导通,P1.i引脚被下拉为低电平,即输出O;CPU输出1时,D=1,=0,场效应管T2截止,P1.i引脚被上拉为高电平,即输出1。23(2)

P1口用作输入口

此时分为“读引脚”和“读锁存器”两种方式。“读引脚”时,与P0口类似,先向P1.i位写1,使场效应管T2截止,P1.i引脚上的输入数据经输入缓冲器BUF2送入内部总线。“读锁存器”时,P1.i锁存器的输出端Q的状态经输入缓冲器BUF1送入内部总线。24

P1口由于有片内上拉电阻,在作为输出口时,不需要在片外接上拉电阻;而且由于没有高阻抗状态,所以P1口是一个准双向口。为了能够从引脚读入正确的数据,当P1口由输出状态转变为输入状态时,应首先向锁存器P1.i写1(执行指令MOVP1,#0FFH)。当单片机复位后,P1.i锁存器被自动置1,可立即作输出口使用。3.P1口的特点254.1.4P2口P2口是一个多功能的8位端口,可以字节访问也可以位访问,其字节访问地址为A0H,位访问地址为A0H~A7H。P2口的各位结构完全相同,但相互之间又是独立的。P2口的某一位的位电路结构图如图4-3所示,其中i的取值范围为0~7。261.位电路结构

从图4-3可以看出,P2.i的电路包含以下内容:(1)一个数据输出锁存器,用于输出数据锁存。(2)两个三态缓冲器BUF1、BUF2,分别用于缓冲锁存器数据和引脚数据。(3)一个2选1的数据选择器MUX21,其中一个输入来自锁存器的Q端,另一个输入为“地址”信号,选择控制端为“控制”。(4)数据输出的驱动电路和控制电路,由一个场效应管T2和一个片内上拉电阻组成。272.工作过程分析P2口有两个功能:用作地址总线和通用I/O口。

(1)

P2口用作输出16位地址总线的高8位地址。在内部“控制”信号作用下,MAX21选择“地址”输出到反相器的输入端。当“地址”为0时,场效应管T2栅极信号为1,T2导通,P2.i引脚输出0;当“地址”为1时,场效应管T2截止,P2.i引脚输出为1。28(2)

P2口用作通用I/O口。

在内部“控制”信号作用下,MAX21选择Q输出到反相器的输入端。当CPU输出0时,Q=0,T2导通,P2.i引脚输出0;当CPU输出1时,Q=0,场效应管T2截止,P2.i引脚输出1。当P2口用作输入口时,此时分为“读引脚”和“读锁存器”两种方式。“读引脚”时,与P0口类似,先向P2.i位写1,使场效应管T2截止,P2.i引脚上的输入数据经输入缓冲器BUF2送入内部总线。“读锁存器”时,P2.i锁存器的输出端Q的状态经输入缓冲器BUF1送入内部总线。29当P2口作为地址输出线使用时,P2口输出16位地址线的高8位地址,与P0口输出的低8位地址一起构成16位地址,可以寻址64KB的地址空间。当P2口作为高8位地址输出时,输出锁存器P2.i的内容保持不变。当P2作为通用I/O口使用时,P2口为一个准双向口,功能与P1口相同。3.P2口的特点304.1.5P3口P3口是一个多功能的8位端口,可以字节访问也可以位访问,其字节访问地址为B0H,位访问地址为B0H~B7H。P3口的各位结构完全相同,但相互之间又是独立的。P3口的某一位的位电路结构图如图4-4所示,其中i的取值范围为0~7。311.位电路结构

从图4-4可以看出,P3.i的电路包含以下内容:

(1)一个数据输出锁存器,用于输出数据锁存。

(2)

3个三态缓冲器BUF1、BUF2和BUF3,分别用于缓冲锁存器数据、引脚数据和第二功能数据。

(3)数据输出的驱动电路和控制电路,由一个“与非门”、一个场效应管T2和一个片内上拉电阻组成。322.工作过程分析P3口有两个功能:通用I/O口(第一功能)和第二输入/输出功能。

(1)

P3口用作通用I/O口。当P3口用作第一功能通用输出时,“第二输出功能”端应置1,使“与非门”处于开启状态,输出由Q端决定。当CPU输出0时,Q=0,场效应管T2导通,P3.i引脚输出为0;当CPU输出1时,Q=1,场效应管T2截止,P3.i引脚输出为1。当P3口用作第一功能通用输入时,为了使场效应管T2截止,不影响输入电平,P3.i锁存器和“第二输出功能”均应置1。33此时,在“读引脚”信号的作用下,P3.i引脚数据通过三态缓冲器BUF3、BUF2进入内部总线。与其他口类似,在“读锁存器”信号的作用下,P2.i锁存器的输出端Q的状态经输入缓冲器BUF1送入内部总线。(2)

P3口用作第二输入/输出功能。与第一功能类似,当选择第二输出功能时,P3.i锁存器置1,使“与非门”处于开启状态,输出由“第二输出功能”端决定。当“第二输出功能”端输出为0时,场效应管T2导通,P3.i引脚输出为0;当“第二输出功能”端输出为1时,场效应管T2截止,P3.i引脚输出为1。34与第一功能类似,当选择第二输入功能时,P3.i锁存器和“第二输出功能”均应置1,保证场效应管T2处于截止状态。此时,P3.i引脚输入的“第二功能”信息由输入缓冲器BUF3的输出送至内部引线“第二输入功能”。35

P3口片内有上拉电阻,无论是第一功能——通用I/O口,还是第二功能,皆为准双向口。无论P3口用作通用I/O口的输入口,还是用作第二功能的输入/输出口,都需要将P3.i锁存器置1。在实际应用中,由于复位后P3.i锁存器的初值为1,所以,P3口可以直接用作第二功能的输入/输出口而不需要做任何设置。由于P3口各个位相互独立,当某一位不作为第二功能使用时,可以作为通用I/O口使用。3.P3口的特点36P3.0——RXD,串行输入口。P3.1——TXD,串行输出口。P3.2——INT0,外部中断0的请求。P3.3——INT1,外部中断1的请求。P3.4——T0,定时器/计数器0外部计数脉冲输入。P3.5——T1,定时器/计数器1外部计数脉冲输入。P3.6——WR,外部数据存储器写选通,输出,低电平有效。P3.7——RD,外部数据存储器读选通,输出,低电平有效。P3口的第二功能定义如下:374.1.6并行I/O接口的编程和使用

例4.1P1口输入/输出的简单应用,按键控制LED的点亮和熄灭。电路图如图4-5所示。38解:程序如下:

ORG 0000H LJMP MAIN ORG 0030HMAIN: MOV P1,#80H;P1.7写“1”,作为输入口线ST1: JB P1.7,$;检测P1.7是否为0,是,则按键按下 LCALL DELAY ;延时,去除按键抖动 JB P1.7,$;检测P1.7是否为0,是,则确认按键 ;按下39 JNBP1.7,$;检测按键是否抬起 CPL P1.0 ;LED点亮或熄灭 SJMPST1 END404.2.1定时器/计数器概述4.2定时器/计数器

定时器/计数器(Timer/Counter)是单片机中重要的功能部件之一,其工作方式灵活、编程简单,对减轻CPU的负担和简化外围工作电路有重要意义。以STC89C51系列单片机为例,单片机的定时器/计数器有以下特点:(1)

STC89C51单片机包含有2个16位的定时器/计数器:定时器/计数器T0和定时器/计数器T1。(2)

STC89C52单片机包含有3个16位的定时器/计数器:定时器/计数器T0、定时器/计数器T1和定时器/计数器T2。41(3)

定时器/计数器的核心是一个加1计数器,其基本功能是加1功能。在单片机的T0、T1或T2引脚上施加一个1到0的跳变,计数器加1,即为计数功能;在单片机内部对机器周期或其分频进行计数,计数值与周期的乘积,即为定时时间。在80C51系列单片机中,定时功能和计数功能的设定和控制都是通过软件来进行的。424.2.2定时器/计数T0、T1

定时器/计数器T0、T1的内部结构简图如图4-6所示。从图中可以看出,定时器/计数器T0、T1由以下几部分组成:(1)计数器TH0、TL0和TH1、TL1;(2)特殊功能寄存器TMOD和TCON;(3)时钟分频器;(4)输入引脚T0、T1、INT0和INT1。1.定时器/计数器T0、T1的内部结构44

1)定时器/计数器T0、T1的方式寄存器(TMOD)顾名思义,80C51系列单片机定时器/计数器的方式寄存器TMOD就是用来选择定时器/计数器的工作方式的。方式寄存器TMOD是一个逐位定义的8位寄存器,是只能字节寻址的寄存器,字节地址为89H,其格式如图4-7所示。8位被分作了两组,高4位定义定时器/计数器T1的工作方式,低4位定义定时器/计数器T0的工作方式。下面对TMOD的各位加以说明。2.定时器/计数器T0、T1的特殊功能寄存器45(1)

GATE门控位。

GATE=0时,仅由运行控制位TRi(i=0,1)来控制定时器/计数器计数。

GATE=1时,由外部中断引脚INT0、INT1和TRi来控制定时器/计数器计数。当INT0引脚为高电平时,TR0置位,启动定时器/计数器T0计数;当INT1引脚为高电平时,TR1置位来启动定时器/计数器T1计数。46(2)C/T——计数功能、定时功能选择位。

C/T=0时,选择定时功能,定时器/计数器对单片机的晶振12分频后得到的信号进行计数,以此得到定时的时间。

C/T=1时,选择计数功能,定时器/计数器对外部输入引脚T0(P3.4)或T1(P3.5)的输入脉冲(负跳变)计数。(3)

M1、M0——工作方式选择位。由于有M1和M0两位,所以有四种工作方式见表4-1。47

1)定时器/计数器T0、T1的控制寄存器(TCON)

80C51系列单片机定时器/计数器的控制寄存器TCON是用来控制、指示定时器/计数器的工作状态的。控制寄存器TCON是一个逐位定义的8位寄存器,既可字节寻址,也可位寻址。字节地址为88H,位寻址的地址为88H~8FH,其格式如图4-8所示。48下面对TCON的各位加以说明。

(1)TF1、TF0(TCON.7、TCON.5)——定时器/计数器T1、T0的溢出标志。当定时器/计数器溢出时,该位由内部硬件置位。若中断开放,则响应中断,进入中断服务程序后,由硬件自动清0;若中断禁止,则此位可用于查询方式,作为状态位供CPU查询,当查询有效时,进入处理程序后,及时用软件将此位清0。(2)

TR1、TR0(TCON.6、TCON.4)——定时器/计数器T1、T0的运行控制位。用软件控制,置1时,启动T1;清0时,停止T1。49TCON的低4位与外部中断有关,将在后续章节中详细讨论。复位后,TCON的所有位均清0。50

3)定时器/计数器T0、T1的数据寄存器(TH1、TL1和TH0、TL0)

定时器/计数器T0、T1各有1个16位的数据寄存器,它们都是由高8位寄存器和低8位寄存器所组成的。这些寄存器不经过缓冲,直接显示当前的计数值。这4个寄存器都是读/写寄存器,任何时候都可对它们进行读/写操作。复位后,所有这4个寄存器全部清0。它们都只能字节寻址,相应的字节地址见表4-2。51定时器/计数器T0、T1的工作模式是通过TMOD中的C/T位来选择的。1)定时器(C/T=0)此时,计数输入信号是内部时钟脉冲,每个机器周期使寄存器的值加1。每个机器周期包含12个振荡周期,故计数速率为振荡周期的1/12。当采用12MHz的晶体时,计数速率为1MHz。定时器的定时时间与系统的振荡频率有关,与计数器的长度和初值有关。3.定时器/计数器T0、T1的定时、计数模式选择52

2)计数器(C/T=1)这时,通过引脚T0(P3.4)和T1(P3.5)对外部信号进行计数。在每个机器周期,CPU都采样引脚的输入电平。若前一机器周期采样值为1,下一机器周期采样值为0,则计数器加1,此后的机器周期,新的计数值装入计数器,周而复始,直至计数器溢出。由此可知,在计数模式下,检测到一个1到0的跳变(下降沿)需要2个机器周期,故最高计数频率为振荡频率的1/24。53通过设置M1和M0的值,定时器/计数器T0、T1可选择4种不同的工作方式。下面分别介绍。1)方式0当TMOD中的M1M0=00时,定时器/计数器被设置为工作方式0。这时定时器/计数器的逻辑结构框图如图4-9所示。这种方式下,计数寄存器由13位组成,即TLi的高3位未用。计数时,TLi的低5位溢出后向THi进位,THi溢出后使TFi置位,并向CPU申请中断。如果中断允许,CPU响应中断并转入中断服务程序,由内部硬件清TFi。TFi也可以由程序查询和清0。4.定时器/计数器T0、T1的4种工作方式是否计数,由GATE、INTi引脚、TRi三部分决定,一般先设定GATE位。

(1)当GATE=0时,A点为高电平,定时器/计数器的启动/停止由TRi决定。TRi=1,定时器/计数器启动;TRi=0,定时器/计数器停止。

(2)当GATE=1时,A点的电位由INTi决定,因而B点的电位由TRi和INTi决定,即定时器/计数器的启动/停止由TRi和INTi两个条件决定。2)方式1当TMOD中的M1M0=01时,定时器/计数器被设置为工作方式1。这时定时器/计数器的逻辑结构框图如图4-10所示。这种方式下,计数寄存器由16位组成。图4-10

定时器/计数器方式1逻辑结构框图计数时,TLi溢出后向THi进位,THi溢出后使TFi置位,并向CPU申请中断。如果中断允许,CPU响应中断并转入中断服务程序,由内部硬件清TFi。TFi也可以由程序查询和清0。其他与方式0完全相同。

3)方式2当TMOD中的M1M0=10时,定时器/计数器被设置为工作方式2。这时定时器/计数器的逻辑结构框图如图4-11所示。这种方式将16位计数寄存器分为2个8位寄存器,组成一个自动重装载的8位计数寄存器。在方式2中,TLi作为8位计数寄存器,THi作为8位计数常数寄存器。当TLi计数溢出时,一方面将TFi置位,并向CPU申请中断;另一方面,将THi的内容自动加载到TLi中,继续计数。重装载不影响THi的内容,因而可以多次连续加载。

方式2对定时控制特别有用,它可实现每隔预定时间发出控制信号,而且特别适合于串行口波特率发生器的使用。

4)方式3当TMOD中的M1M0=11时,定时器/计数器被设置为工作方式3。这种方式将定时器/计数器T0分为一个8位定时器/计数器和一个8位定时器,TL0用于8位定时器/计数器,TH0用于8位定时器。这时定时器/计数器T0的逻辑结构框图如图4-12所示。定时器/计数器方式3下定时器/计数器T0的工作方式与方式0、1时相同,只是此时的计数器为8位计数寄存器TL0,它占用了定时器/计数器T0的GATE、、TR0、T0引脚以及中断源等。由于定时器/计数器T0的资源已被计数寄存器TL0所占用,所以TH0只能作为定时器用,而且TH0占用了定时器/计数器T1的启动/停止控制位TR1、计数溢出标志位TF1及中断源。在定时器/计数器方式3下,定时器/计数器T1的结构如图4-13所示。此时定时器/计数器T1可选方式为0、1或2。因为此时中断源已被占用,所以仅能作为波特率发生器或用在其他不用中断的地方。事实上,只在定时器/计数器T1用作波特率发生器时,定时器/计数器T0才选作方式3。634.2.3定时器/计数T280C52中有一个功能强大的定时器/计数器T2,它是一个16位的、具有自动重装载和捕获能力的定时器/计数器。在定时器/计数器T2的内部,除了两个8位计数器TL2、TH2和控制寄存器T2CON、方式寄存器T2MOD之外,还设置有捕获寄存器RCAP2L(低字节)和RCAP2H(高字节)。定时器/计数器T2的计数脉冲源可以有两个:一个是内部机器周期,另一个是由T2(P1.0)端输入的外部计数脉冲。输入引脚T2(P1.0)是外部计数脉冲输入端。输入引脚T2EX(P1.1)是外部控制信号输入端。64

1)定时器/计数器T2的控制寄存器(T2CON)控制寄存器T2CON是一个逐位定义的8位寄存器,既可字节寻址,也可位寻址。字节地址为0C8H,位寻址的地址为0C8H~0CFH,其格式如图4-14所示。1.定时器/计数器T2的特殊功能寄存器下面对T2CON的各位加以说明。

(1)

TF2——定时器/计数器T2溢出标志。定时器/计数器T2溢出时置位,并申请中断。只能软件清除此标志位。当RCLK=l或TCLK=l时,即T2工作在波特率发生器方式下时,定时器/计数器T2的溢出不影响TF2,即TF2不置1。(2)

EXF2——定时器/计数器T2外部标志。当EXEN2=1,且T2EX引脚上出现下降沿而造成捕获或重装载时,EXF2置位,并申请中断。此时若已允许定时器/计数器T2中断,则CPU将响应中断,转向中断服务程序。只能软件清除此标志位。

(3)

RCLK——接收时钟标志位。此标志位由软件置位或清0,用以选择定时器/计数器T2或T1作串行口接收波特率发生器。RCLK=1时,用定时器/计数器T2溢出脉冲作为串行口的接收时钟;RCLK=0时,用定时器/计数器T1的溢出脉冲作接收时钟。(4)

TCLK——发送时钟标志位。此标志位由软件置位或清0,用以选择定时器/计数器T2或T1作串行口发送波特率发生器。TCLK=l时,用定时器/计数器T2溢出脉冲作为串行口的发送时钟;TCLK=0时,用定时器/计数器Tl的溢出脉冲作为串行口的发送时钟。

(5)

EXEN2——定时器/计数器T2外部允许标志。此标志位由软件置位或清0。当EXEN2=1时,允许用外部信号来触发捕获或重装载操作;若定时器/计数器T2未用作串行口的波特率发生器,当在T2EX端出现下降沿信号时,将导致定时器/计数器T2捕获或重装载,并置EXF2标志为1,请求中断。当EXEN2=0时,禁止用外部信号来触发捕获或重装载操作,即T2EX端的外部信号不起作用。(6)

TR2——定时器/计数器T2运行控制位。此标志位由软件置位或清0,以决定定时器/计数器T2是否运行。TR2=l,启动定时器/计数器T2;TR2=0,则停止定时器/计数器T2。

(7)

——C/T2定时器/计数器T2的定时器方式或计数器方式选择位。此标志位由软件置位或清0。C/T2=0,选择定时器工作方式;C/T2=1,选择计数器工作方式,由下降沿触发计数。

(8)

——CP/RL2捕获/重装载标志。此标志位由软件置位或清0。CP/RL2=1,选择捕获功能,这时当EXEN2=1且T2EX端出现信号下降沿时,发生捕获操作。CP/RL2=0,选择重装载功能,这时若定时器/计数器T2溢出或EXEN2=1,且T2EX端出现下降沿信号,都会导致自动重装载操作。当RCLK+TCLK=l时,此控制位不起作用,定时器/计数器T2被强制工作于重装载方式。重装载发生于定时器/计数器T2溢出时,常用作波特率发生器。

2)定时器/计数器T2的方式寄存器(T2MOD)当方式寄存器T2MOD的字节地址为0C9H,不可位寻址,其格式如图4-15所示。虽然方式寄存器T2MOD有8位,但只定义了2位,其余位保留,且复位值均为0。下面对T2MOD定义的2位加以说明。

(1)

T2OE:定时/计数器T2输出允许控制位。当T2OE=1时,启动定时器/计数器T2的可编程时钟输出功能,允许时钟输出至引脚T2(P1.0);当T2OE=0时,禁止引脚T2(P1.0)输出。(2)

DCEN:定时/计数器T2加减计数控制位。当DCEN=1时,允许T2作为加/减计数器使用。具体的计数方向由T2EX引脚来控制,当T2EX=1时,T2进行加计数;当T2EX=O时,T2进行减计数。DCEN=0时,T2自动加计数。

3)定时器/计数器T2的数据寄存器(TH2、TL2)定时器/计数器T2的数据寄存器是一个16位寄存器,它由高8位寄存器(TH2)和低8位寄存器(TL2)所组成,相应的字节地址为OCDH和OCCH,只能字节寻址。这两个寄存器都是读/写寄存器。复位后,这2个寄存器全部清0。

4)定时器/计数器T2的捕获寄存器(RCAP2H、RCAP2L)定时器/计数器T2中的捕获寄存器是一个16位寄存器,由高8位寄存器(RCAP2H)和低8位寄存器(RCAP2L)所组成,相应的字节地址为OCBH和OCAH,只能字节寻址。RCAP2H、RCAP2L用于捕获计数器TL2、TH2的计数状态,或用来预置计数初值。TH2、TL2和RCAP2H、RCAP2L之间接有双向缓冲器(三态门),用于捕获或者重装载。复位后,这两个寄存器全部清0。74定时器/计数器T2的工作模式是通过T2CON中的位C/T2来选择的。

1)定时器(C/T2=0)此时,T2与T0、T1相似,计数输入信号是内部时钟脉冲,计数速率为振荡周期的1/12,即每个机器周期使(TH2、TL2)寄存器的值加1。

2)计数器(C/T2=1)这时,通过引脚T2(P1.0)对外部信号进行计数,T2的工作情况和时序关系与T0、T1完全一样,对外部计数脉冲的要2.定时器/计数器T2的定时、计数模式选择75求也相同,即外部脉冲的最高频率为振荡频率的1/24。当有外部脉冲到来时,(TH2、TL2)寄存器的值加1。76通过设置定时器/计数器T2的控制寄存器T2CON中的CP/RL2和RCLK+TCLK的值,定时器/计数器T2可选择3种不同的工作方式(表4-3):捕获方式、自动重装载方式和波特率发生器方式。3.定时器/计数器T2的3种工作方式771)自动重装载方式自动重装载方式是指在一定条件下,自动地将RCAP2H和RCAP2L的数据装入计数器TH2和TL2中。一般说来,RCAP2H和RCAP2L在这里起预置计数初值的功能。对于89C52,其工作的逻辑结构框图如图4-16所示。当CP/RL2=0时,选择自动重装载方式。重装载操作在下述两种情况下发生:(1)当定时器/计数器T2的寄存器(TH2、TL2)溢出时,打开重装载三态缓冲器,把(RCAP2H、RCAP2L)的内容自动装载到(TH2、TL2)中(重装载操作)。同时,溢出标志TF2置1,申请中断。79(2)当EXEN2=1且端口T2EX(P1.1)出现下降沿信号时,将发生重装载操作。同时,标志位EXF2置1,申请中断。若定时器/计数器T2的中断是被允许的,则无论发生TF2=1还是EXF2=1,CPU都会响应中断,此中断向量的地址为2BH。响应中断后,应采用软件方式撤除中断申请,以正确地响应新的中断。TF2和EXF2都是直接可寻址位,可采用指令“CLRTF2”和“CLREXF2”撤除中断申请。802)捕获方式捕获方式是指在一定条件下,自动将计数器TH2和TL2的数据读入RCAP2H和RCAP2L,即TH2和TL2内容的捕获是通过捕获寄存器RCAP2H和RCAP2L来实现的。对于89C52,其工作的逻辑结构框图如图4-17所示。81

当CP/RL2=1时,选择捕获方式。中断和捕获操作在下述两种情况下发生:(1)当定时器/计数器T2的寄存器(TH2、TL2)溢出时,溢出标志TF2置1,申请中断。(2)当EXEN2=1且端口T2EX(P1.1)出现下降沿信号时,打开捕获三态缓冲器,把(TH2、TL2)的内容自动读入到(RCAP2H、RCAP2L)中(捕获操作)。同时标志位EXF2置1,申请中断。

若定时器/计数器T2的中断是被允许的,则无论发生TF2=1还是EXF2=1,CPU都会响应中断,此中断向量的地址为2BH。响应中断后,应采用软件方式撤除中断申请,以正确地82响应新的中断。TF2和EXF2都是直接可寻址位,可采用指令“CLRTF2”和“CLREXF2”撤除中断申请。833)波特率发生器方式当T2CON中的RCLK+TCLK=1时,定时器/计数器T2将工作于波特率发生器方式,即其溢出脉冲用作串行口的时钟。定时器/计数器T2的波特率发生器方式下的逻辑结构框图如图4-18所示。在T2CON中,RCLK选择串行通信接收波特率发生器,TCLK选择串行通信发送波特率发生器。因此,发送和接收的波特率可以不同。此时,定时器/计数器T2的输入时钟脉冲可由内部时钟电路决定,也可由外部时钟电路决定。(1)若C/T2=0,选用内部时钟,计数脉冲的频率为振荡器频率的1/2。图4-18

波特率发生器方式逻辑结构框图85(2)若C/T2=1,选用外部时钟,该时钟由T2(P1.0)端输入,每当外部信号产生下降沿时,计数器值加1。外部脉冲频率不超过振荡器频率的1/24。由于脉冲溢出时,RCAP2H、RCAP2L的内容会自动装载到TH2、TL2中,故波特率的值还决定于RCAP2H、RCAP2L的装载初值。

RCLK+TCLK还用于选择定时器/计数器T1还是T2作串行通信的波特率发生器。由图4-18可看出,这两位的值用来控制两个电子开关的位置。值为0时,选用定时器/计数器T1作波特率发生器;值为1时,选用定时器/计数器T2作波特率发生器。86

当定时器/计数器T2用作波特率发生器时,TH2的溢出不会使TF2置位,即不会产生中断请求。因此,可以不禁止中断。当定时器/计数器T2用作波特率发生器时,若EXEN2置1,则端口T2EX的信号产生下降沿时,EXF2将置1,但不会发生重装载或捕获操作。这时,端口T2EX可以作为一个额外的外部中断源。在波特率发生器工作方式下,在T2计数过程中(即在TR2=1之后),不能再读/写TH2、TL2的内容。如果读,则读出的结果不会精确(因为每个状态加1);如果写,则会影响T2的溢出而使波特率不稳定。在T2计数过程中,可以读出但不能87改写RCAP2H、RCAP2L的内容。若需要访问RCAP2H、RCAP2L,则应事先关闭定时器。884.2.4定时器/计数器的编程和使用

在定时器/计数器的4种工作方式中,方式0与方式1基本相同,只是计数器位数不同:方式0为13位计数器,方式1为16位计数器。方式0的存在是为了兼容MCS-48,而且方式0的计数初值计算麻烦,所以在实际使用中,一般不使用方式0,而使用方式1。89

例4.2设晶振频率fosc=6MHz,使用定时器/计数器T1以方式1产生周期为2ms的方波脉冲,并由P1.0输出,如图4-19所示。试以中断方式实现。90

解:方波的周期用定时器T1来确定,即在T1中设置一个初值,在初值的基础上进行计数,每隔1ms计数器T1溢出一次,即产生一次中断。CPU响应中断后,在中断服务程序中对P1.0取反。

(1)

TMOD确定。TMOD取值如图4-20所示。图4-20TMOD取值91(2)计算计数器的计数初值。要产生2ms的方波脉冲,只需在P1.0端以1ms为间隔,交替输出高低电平即可实现。为此,定时间应为1ms。晶振频率fosc=6MHz,则一个机器周期为2s,设待求计数初值为X,则其中:t为定时时间,L为计数器位数,X为计数初值,tc为计数周期。

1000×10-6=(216-X)×2×10-6即500=216-X

X=216-500=10000H-1F4H92

X=216-500=10000H-1F4H

=0FE0CH=1111111000001100B所以,初值为TH1=0FEH,TL1=0CH。

(3)采用中断方式。编程时打开全局和局部中断。设置EA=1,ET1=1,以允许T1中断。

(4)定时器的启动。由定时器控制寄存器TCON中的TR1位控制定时器的启动和停止。

TR1=1,启动;TR1=0,停止。(5)程序设计。中断服务程序除了产生方波以外,还需将计数初值重新装入计数器,以便产生方波序列。93程序如下:

ORG 0000H LJMP MAIN ;主程序入口

ORG 001BH LJMP INTT1 ;T1中断入口

ORG 0030HMAIN: MOV SP,#60H ;修改堆栈指针

MOV TMOD,#10H ;T1为方式1 MOV TH1,#0FEH ;设置计数初值

MOV TL1,#0CH94 SETB EA ;允许中断

SETB ET1 ;允许T1中断 SETB TR1 ;启动T1 SJMP $ ;等待中断INTT1: MOV TH1,#0FEH ;重新设置初值

MOV TL1,#0CH CPL P1.0 ;定时1ms时间到,输出取反 RETI END95

例4.3设晶振频率fosc=6MHz,使用定时器/计数器T0以方式2产生周期为400s的方波脉冲,并由P1.0输出,如图4-21所示。试以中断方式实现。图4-21

在P1.0引脚上输出的波形96

解:方波的周期用定时器T0来确定,即在T0中设置一个初值,在初值的的基础上进行计数,每隔200µs计数器T0溢出一次,即产生一次中断。CPU响应中断后,在中断服务程序中对P1.0取反。

(1)

TMOD确定。TMOD取值如图4-22所示。图4-22TMOD取值97(2)计算计数器的计数初值。要产生400µs的方波脉冲,只需在P1.0端以200µs为间隔,交替输出高低电平即可实现。为此,定时间应为200µs。晶振频率fosc=6MHz,则一个机器周期为2µs,设待求计数初值为X,则

200×10-6=(28-X)×2×10-6即100=28-XX=28-100=100H-64H=9CH=10011100B所以,初值为TH0=9CH,TL0=9CH。

(3)采用中断方式。编程时打开全局和局部中断。设置EA=1,ET0=1,以允许T0中断。98

(4)定时器的启动。由定时器控制寄存器TCON中的TR0位控制定时器的启动和停止。

TR0=1,启动;TR0=0,停止。(5)程序设计。中断服务程序只需产生方波方波序列即可。程序如下:

ORG 0000H LJMP MAIN ;主程序入口

ORG 000BH LJMP INTT0 ;T1中断入口

ORG 0030H99MAIN: MOV SP,#60H ;修改堆栈指针

MOV TMOD,#02H ;T0为方式2 MOV TH0,#9CH ;设置计数初值

MOV TL0,#9CH SETB EA ;允许中断

SETB ET0 ;允许T0中断

SETB TR0 ;启动T0 SJMP $ ;等待中断INTT0:100 CPL P1.0 ;定时200s时间到,输出取反

RETI END101

例4.4门控制位GATE的应用——测量脉冲宽度。下面以T1为例,介绍门控制位GATE的应用。门控制位GATE可使定时器/计数器T1的启动计数受INT1的控制,当GATE=1,TR1=1时,只有INT1引脚输入高电平时,T1才被允许计数,利用GATE位的这一功能(对于T0的GATE位也是一样,可使T0的启动计数受INT0的控制),可测量INT1引脚(P3.3)上正脉冲的宽度(机器周期数),其方法如图4-23所示。图4-23利用GATE位测量正脉冲的宽度102参考程序如下:

ORG 0000H LJMP MAIN ;复位入口转主程序

ORG 0030HMAIN: MOV SP,#60H MOV TMOD,#90H ;向TMOD写控制字,T1为方式

;1定时,GATE=1 MOV TL1,#00H MOV TH1,#00H JB P3.3,$ ;等待降低103

SETB TR1 ;如果为低,启动T1,计数器

;开始计数

JNB P3.3,$ ;等待升高

JB P3.3,$ ;为高,等待降低

CLR TR1 ;停止T1计数

MOV A,TL1 ;T1计数值送A …执行以上程序,使引脚上出现的正脉冲宽度以机器周期数的形式显示在显示器上。1044.3中断系统

中断系统在单片机系统中起着十分重要的作用。一个功能很强的中断系统,能大大提高单片机处理事件的能力,提高效率,增强实时性。80C51系列微控制器(单片机)的中断功能较强,共设有6个中断源,6个中断矢量:T0、T1、T2、、和一个串行通信中断矢量。有两级中断优先级,可实现两级中断嵌套。用户可以很方便地通过软件实现对中断的控制。1054.3.1中断系统概述

程序执行过程中,允许外部或内部事件通过硬件中断程序的执行,使其转向处理外部或内部事件的中断服务程序中;完成中断服务程序后,CPU继续原来被打断的程序,这样的过程称为中断。中断响应和处理过程如图4-24所示。1.中断1062.中断源

能产生中断的外部和内部事件称为中断源,如键盘中断、A/D转换器中断(当A/D转换器结束模拟量到数字量的转换而产生的中断)、定时中断(定时器/计数器产生的中断)、程序性中断(为调试程序而设置断点、单步工作等)。对于每个中断源,不仅要求能发出中断请求信号,还要求这个信号能保持一定的时间,直至CPU响应这个中断请求后才能且必须撤销这个中断请求信号。这样既不会因CPU未及时响应而丢失中断申请信号,也不会出现多次重复中断的情况。1073.中断优先级

几个中断源同时申请中断时,或者CPU正在处理某外部事件时,又有另一外部事件申请中断,CPU必须区分哪个中断源更重要,从而确定优先处理哪个中断源,这就是中断优先级问题。就后者来说,优先级高的事件可以中断CPU正在处理的低级的中断服务程序,待完成了高级中断服务程序之后,再继续被中断的低级中断服务程序。在80C51系列微控制器中,只有两级中断优先级。图4-25是80C51系列微控制器的中断系统结构示意图。图4-25

80C51系列微控制器的中断系统结构示意图1094.3.2中断的控制和操作80C51系列微控制器中有5个中断源。80C52系列微控制器中增加了一个定时器/计数器T2中断源,即有6个中断源。80C52的6个中断源如下。

(1)(P3.2)——外部中断0。当IT0(TCON.0)=0时,低电平有效;当ITO(TCON.0)=1时,下降沿有效。

(2)(P3.3)——外部中断1。当IT0(TCON.2)=0时,低电平有效;当IT1(TCON.2)=1时,下降沿有效。

(3)

TF0(P3.4)——定时器/计数器T0溢出中断。1.80C52系列微控制器中断源110(4)

TF1(P3.5)——定时器/计数器T1溢出中断。

(5)

RI,TI——串行中断。

(6)

TF2、EXF2——定时器/计数器T2溢出中断。微控制器各中断源提出的中断申请,如果得到微控制器的中断响应,则会自动转入各自固定的中断入口地址(中断矢量)见表4-4。1112.中断标志INT0、INT1、T0及T1的中断标志存放在定时器/计数器控制寄存器TCON中,串行口的中断标志存放在串行口控制寄存器SCON中,T2的中断标志存放在定时器/计数器T2的控制寄存器T2CON中。

TCON寄存器字节地址为88H,其格式如图4-26所示。图4-26定时器/计数器控制寄存器TCON格式112SCON寄存器字节地址为98H,其格式如图4-27所示。图4-27串行口控制寄存器SCON格式T2CON寄存器字节地址为0C8H,其格式如图4-28所示。图4-28定时器/计数器控制寄存器T2CON格式113

下面对中断标志及控制位的各位加以说明。(1)

TF2(T2CON.7)——定时器/计数器T2溢出标志。定时器/计数器T2溢出时置位,并申请中断。响应中断后需用软件清0。(2)

EXF2(T2CON.6)——定时器/计数器T2外部标志。当EXEN2=1,且T2EX引脚上出现下降沿而造成捕获或重装载时,EXF2置位,并申请中断。响应中断后需用软件清0。(3)

TF1(TCON.7)——定时器/计数器T1溢出标志。硬件置位,响应中断后硬件清0。不用中断时,需用软件清0。(4)

TF0(TCON.5)——定时器/计数器T0溢出标志。硬件置位,响应中断后硬件清0。不用中断时,需用软件清0。114

下面对中断标志及控制位的各位加以说明。(1)

TF2(T2CON.7)——定时器/计数器T2溢出标志。定时器/计数器T2溢出时置位,并申请中断。响应中断后需用软件清0。(2)

EXF2(T2CON.6)——定时器/计数器T2外部标志。当EXEN2=1,且T2EX引脚上出现下降沿而造成捕获或重装载时,EXF2置位,并申请中断。响应中断后需用软件清0。(3)

TF1(TCON.7)——定时器/计数器T1溢出标志。硬件置位,响应中断后硬件清0。不用中断时,需用软件清0。(4)

TF0(TCON.5)——定时器/计数器T0溢出标志。硬件置位,响应中断后硬件清0。不用中断时,需用软件清0。115(5)

IE1(TCON.3)——外部中断请求1的中断标志。IE1=1时,INT1向CPU申请中断。

(6)

IE0(TCON.1)——外部中断请求0的中断标志。IE0=1时,INT0向CPU申请中断。

(7)

TI(SCON.1)——串行口发送中断标志。发送完一帧,硬件置位。响应中断后需用软件清0。

(8)

RI(SCON.0)——串行口接收中断标志。接收完一帧,硬件置位。响应中断后需用软件清0。

(9)

IT1(TCON.2)——外部中断请求触发方式控制位。

IT1=0,电平触发方式,引脚上的外部中断请求输入信号为低电平有效,并使IT1置位。进入中断服务程序后,由硬116件自动将IE1清0。IT1=1,下降沿触发方式,引脚上的外部中断请求输入信号电平从高到低的跳变有效,并使IT1置位。进入中断服务程序后,由硬件自动将IE1清0。

(10)

IT0(TCON.0)——外部中断请求触发方式控制位。

IT0=0,电平触发方式,引脚上的外部中断请求输入信号为低电平有效,并使IT0置位。进入中断服务程序后,由硬件自动将IE0清0。

IT0=1,下降沿触发方式,引脚上的外部中断请求输入信号电平从高到低的跳变有效,并使IT0置位。进入中断服务程序后,由硬件自动将IE0清0。1173.中断允许控制

中断允许和禁止由中断允许寄存器控制。中断允许寄存器IE是一个逐位定义的8位寄存器,既可字节寻址,也可位寻址。字节地址为0A8H,位寻址的地址为0A8H~0AFH。其格式如图4-29所示。图4-29中断允许寄存器IE格式

中断中断允许寄存器IE中的各位为0时,禁止相应中断;为1时,允许相应中断。系统复位后,中断允许寄存器IE中各位均为0,即此时禁止所有中断。下面对IE的各位加以说明。118EX0(IE.0)——外部中断0中断允许位。ET0(IE.1)——定时器/计数器T0中断允许位。EX1(IE.2)——外部中断1中断允许位。ET1(IE.3)——定时器/计数器T1中断允许位。ES(IE.4)——串行口中断允许位。ET2(IE.5)——定时器/计数器T2中断允许位。EA(IE.7)——CPU中断允许位(中断总允许位)。EA=1时,开放所有中断;EA=0时,屏蔽所有中断。1194.中断优先级

在80C51系列单片机中有高、低两个中断优先级,通过中断优先级寄存器IP来设定。中断优先级寄存器IP是一个逐位定义的8位寄存器,既可字节寻址,也可位寻址。字节地址为0B8H,位寻址的地址为0B8H~0BFH。其格式如图4-30所示。

中断中断优先级寄存器IP中的各位为0时,相应中断为低优先级;为1时,相应中断为高优先级。系统复位后,IP寄存器中各位均为0,即此时全部中断设定为低优先级。图4-30中断优先级寄存器IP格式120PX0(IP.0)——外部中断0中断优先级控制位。PT0(IP.1)——定时器/计数器T0中断优先级控制位。PX1(IP.2)——外部中断1中断优先级控制位。PT1(IE.3)——定时器/计数器T1中断优先级控制位。PS(IP.4)——串行口中断优先级控制位。PT2(IP.5)——定时器/计数器T2中断优先级控制位。下面对IP的各位加以说明。

在中断执行过程中,所有允许的高优先级中断可以中断低优先级中断的执行过程。同级的中断不能相互中断。几个同级的中断源同时向CPU121申请中断时,CPU按硬件次序排定优先权,即依次为INT0、T0、INT1、T1、串行口和T2。1224.3.3中断过程

中断请求就是中断源向CPU申请中断的过程,即建立中断请求标志位IE0、IE1、TF0、TF1、TF2/EXF2、TI/RI的过程。

1)外部中断请求外部中断源INT0、INT0经由引脚P3.2、P3.3向CPU申请中断。外部中断请求有两种方式:电平触发方式和下降沿触发方式。通过设置触发方式控制位IT0、IT1进行选择。对于定时器/计数器T2的控制端T2EX来说,只有下降沿触发方式1.中断请求123,控制端T2EX的下降沿经由引脚P1.1向CPU申请中断。(1)电平触发方式。若外部中断定义为电平触发方式,外部中断请求触发器的状态随着CPU在每个机器周期采样到的外部中断源输入线的电平变化而变化,这能提高CPU对外部中断请求的响应速度,但是也存在缺陷。这是因为在电平触发方式,单片机不锁存电平触发中断请求信号,会把每个机器周期采样到的外部中断源输入线上的逻辑电平直接赋值给中断标志寄存器。当中断请求被阻塞而没有得到及时响应时,将会被丢失。所以,要使电平触发的中断被CPU响应并执行,必须保证外部中断源输入线上的低电平维持到中断被执行为止。124当外部中断源被设定为电平触发方式时,在中断服务程序返回之前,外部中断请求输入必须无效(即外部中断请求为高电平),否则,CPU返回主程序后会再次响应中断。所以,在电平触发方式,需要CPU能够清除外部中断请求源。(2)下降沿触发方式。当CPU在一个机器周期中检测到中断源输入线上的电平为高电平,下一个机器周期检测到低电平,即电平信号有一个从高到低的跳变时,CPU即置位中断标志,申请中断。所以,为确保检测到下降沿,中断源输入线上的高电平和低电平应至少各自保持一个机器周期。当中断标志寄存器锁存下降沿中断请求信号后,直到CPU响应中断并进入中断服务程序时,才由硬件自动清除。因此,在下降沿触发125方式,当CPU正在执行同级或高级中断时,产生的外部中断同样会被记录到中断标志寄存器中。在同级或高级中断执行完毕后,该中断将被响应并执行。外部中断请求标志存放在IE0、IE1中。

IE0为INT0中断请求标志位,当INT0有中断请求时IE0置位,在CPU响应中断后,由硬件将IE0清0。

IE1为INT1中断请求标志位,当INT1有中断请求时IE1置位,在CPU响应中断后,由硬件将IE1清0。对于定时器/计数器T2的外部标志EXF2来说,当T2EX的下降沿来临,且EXEN2置位时,则置位EXF2并申请中断。在CPU响应中断后,只能由软件将EXF2清0。126

2)内部中断请求当定时器/计数器T0计数产生溢出时,由硬件置位TF0。当CPU响应中断后,再由硬件将TF0清0。当定时器/计数器T1计数产生溢出时,由硬件置位TF1。当CPU响应中断后,再由硬件将TF1清0。当定时器/计数器T2计数产生溢出时,由硬件置位TF2。当CPU响应中断后,只能由软件将TF2清0。对于串行口中断来说,有两个标志位:TI、RI。当串行口发送完一个字节数据后,置位TI;当串行口接收完一个字节数据后,置位RI。CPU响应中断后,只能由软件将TI、RI清0。1272.中断响应CPU对中断请求进行判断,形成中断矢量,转入相应的中断服务程序的过程称为中断响应。只有满足规定要求的中断请求才能被CPU响应。

1)

CPU响应中断的基本条件一个中断源的中断申请被响应,需满足以下基本条件。有中断源提出中断申请。中断总允许位EA=1,即CPU开放中断。申请中断的中断源的中断允许位为1,即开放中断源。CPU没有响应同级或更高优先级的中断。当前指令执行结束。128如果正在执行的指令是RETI或是访问IE、IP指令,则CPU在执行RETI或访问IE、IP指令后,至少还要再执行一条其他指令后才会响应中断请求。在接收中断申请时,如遇下列情况,硬件生成的长调用指令“LCALL”将被封锁:

(1)正在执行同级或高优先级的中断服务程序。

(2)所查询的机器周期不是执行当前指令的最后一

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论