《[信息与通信]第九章可编程计数器定时器8253及其应用.ppt》由会员分享,可在线阅读,更多相关《[信息与通信]第九章可编程计数器定时器8253及其应用.ppt(50页珍藏版)》请在三一办公上搜索。
1、,第九章 可编程计数器/定时器8253及应用,9-1 8253工作原理 一、8253的内部结构与引脚信号 二、8253的初始化编程 三、8253的工作方式 四、8253与系统的连接 9-2 8253的应用举例 一、8253定时功能举例 二、8253计数功能举例,9-1 8253工作原理,计算机中,经常用到定时功能,如:动态RAM刷新、系统时间、日历、定时检测参数等都需要定时信号。实现定时功能主要有三种方法:1、软件定时 2、不可编程的硬件定时 3、可编程的硬件定时,软件定时(也称软件延时)定时时间由软件编程(循环执行某段程序)来控制。方法简单、费用低;但CPU的利用率低。不可编程的硬件定时 定
2、时时间由不可编程器件和外围电路控制,通过改变电路参数,可在一定的范围内改变定时时间,定时精度不高。如:555芯片。可编程的硬件定时 定时时间和范围是通过软件对可编程器件进行编程控制,由CPU的时钟信号提供时间基准,定时精确。与CPU并行工作,应用比较广泛,如8253,8254。,三种定时方法,Intel 8253是一种可编程的计数器/定时器芯片。8253内部具有3个独立的16位计数器通道,通过对它进行编程,每个计数器通道均有6种工作方式,并且都可以按2进制或10进制2种格式进行计数,最高计数频率能达到2MHz。8253还可用作可编程方波频率产生器、分频器、程控单脉冲发生器等。,8253综述,一
3、、8253的内部结构与引脚信号,1、数据总线缓冲器 一个8位双向的三态缓冲器,作为8253和系统数据总线之间的接口;实现CPU与8253之间数据的传送;传送信息包括:进行初始化编程时的控制字 向某一计数器通道写入的计数初值 从某一计数器通道读出的当前计数值,各部分功能简介,2、读/写控制逻辑 接收系统送来的地址和读写信号,组合后形成控制信号对各部分操作进行控制。,各部分功能简介,3、计数器02 8253内部包含3个完全相同且独立的计数器通道 每个通道的内部构成:一个8位的控制字寄存器 一个16位的计数初值寄存器(CR)一个16位计数器执行部件(CE)16位的输出锁存器(OL)每个通道的外部引脚
4、:CLK、GATE、OUT 工作原理:设置工作方式、预置初值、减1计数 两种功能:计数、定时,各部分功能简介,CS,计数器0#VCC 控制寄存器 GND CRH CRL 计数器寄存器(CR)GATE0 CLK0 CEH CEL 计数单元(CE)OUT0 OLH OL 输出锁存器(OL)GATE 1 计数器 1#CLK1 OUT1 GATE2 计数器 2#CLK2 OUT2,D0D7,地址 译码,地址线,A1 A0,RD,WR,4、控制字寄存器 CPU用输出指令向它写入控制字,设置8253工作环境 控制字格式:,各部分功能简介,0 0 0 方式0 0 0 1 方式1 X 1 0 方式2 X 1
5、1 方式3 1 0 0 方式4 1 0 1 方式5,选择计数器 00 选择计数器0的控制寄存器 01 选择计数器1的控制寄存器 10 选择计数器2的控制寄存器 11 非法值,00 将计数器中CE的数据锁存到输出锁存器OL中 01 选计数器的低8位字节读/写 10 选计数器的高8位字节读/写 11 计数器两次操作(先低位,后高位),读出,写入计数器,8253的初始化编程按顺序分两步完成:写入控制字;写入计数初值 1、写入控制字 由OUT指令向控制字寄存器写入,用来选定计数器通道、规定该计数器的工作方式和计数方式。写入控制字还起到复位作用,使输出端OUT变为规定的初始状态,并使计数器清0。,二、8
6、253的初始化编程,2、写入计数初值 由OUT指令向某计数器送一个计数初值,可以是8/16位数据。若是8位数,一条OUT指令即可完成初值的设置;若是16位数,必须用两条OUT指令来完成,且先送低8位数据,后送高8位数据。【注意】若计数初值为0时,要分成两次写入。0在二进制计数方式时,表示65536,BCD计数方式时,表示10000。三个计数器初始化没有先后顺序。,【例】某微机系统中,8253的3个计数器端口地址分别为3F0H、3F2H和3F4H,控制端口地址为3F6H,若要求8253的通道0工作于方式3,计数初值N0=1234,BCD方式计数,编写初始化程序。,初始化编程举例,初始化程序段如下
7、:MOV AL,00110111B MOV DX,3F6H OUT DX,AL MOV AL,34H MOV DX,3F0H OUT DX,AL MOV AL,12H OUT DX,AL,1、方式0计数结束中断方式 时序图,三、8253的工作方式,8253方式0,CW=10H,CLK,GATE,OUT,LSB=6,6,5,4,3,2,1,0,CRCE,CR=6,工作过程 写入控制字,OUT立即变为低;写初值到计数寄存器(CR),若GATE为高电平,下一个时钟脉冲的下降沿将初值装入计数执行部件(CE),才开始减1计数;计数期间,OUT一直为低;当计数结束(计数值为0),OUT变为高,并一直保持到
8、重新装入初值或设置新的工作方式。用途:方式0常用来对外部事件计数,利用OUT由低到高的变化中断请求信号。,8253方式0,两种特殊情况:,8253方式0,CW=10H,CLK,GATE,OUT 1 0,LSB=4,4,3,2,2,2,1,0,CRCE,CR=4,GATE门控信号的改变,两种特殊情况:,8253方式0,CR=3,CW=10H,CLK,GATE,OUT,LSB=3,3,2,1,3,2,1,0,CRCE,CR=3,中途改变计数初值,2、方式1可编程单稳态输出方式 时序图,8253方式1,1,2,CW=12H,CLK,GATE,OUT,LSB=3,3,0,CR=3,工作过程 写入控制字
9、,OUT立即变为高,并保持不变。写计数初值N,只有当GATE形成一个上升沿时,才在下一个时钟脉冲的下降沿,将n装入实际计数器,同时OUT由高变为低,开始减1计数(再来一个脉冲)。计数期间,OUT一直为低;当计数结束(计数值为0),OUT变为高。用途:输出稳态负脉冲 OUT端输出负脉冲的宽度=时钟脉冲宽度计数值N。,8253方式1,注意:在计数过程中,GATE为高、低和下降沿,均不影响计数;但若又来一上升沿,则将计数初值重新装入实际计数器,重新开始计数,使OUT端的负脉冲变长;,8253方式1,3、方式2比率发生器 时序图,8253方式2,CRCE,CRCE,CW=14H,CLK,GATE,OU
10、T,LSB=3,3,2,1,0 3,2,1,0 3,CRCE,CR=3,2,1,工作过程 写控制字,OUT为高。写计数初值,若GATE为高电平,则在下一个时钟脉冲下降沿,将计数初值装入CE,开始减1计数。当计数值减为1时,OUT由高变低,减为0时,OUT又变为高,即OUT输出一个时钟周期的负脉冲;同时,自动将计数初值装入计数执行部件,开始新一轮的计数过程。用途:分频器 若计数器的初值为n,则OUT引脚产生的波形频率为时钟脉冲频率的n分之一。,8253方式2,注意:(1)任何时候重新写入新的计数初值,当原计数值减为0时,才按新写入的计数值进行计数;(2)计数过程中,当GATE再产生上升沿时,在下
11、一个时钟脉冲下降沿,重新将计数初值装入实际计数器,开始减1计数。,8253方式2,4、方式3方波发生器 时序图,8253方式3,CRCE,CW=16H,CLK,GATE,OUT,LSB=4,4,2,4,2,4,2,4,CRCE,CR=4,2,4,计数初值为偶数时的波形,CRCE,CRCE,CRCE,8253方式3,2,CRCE,CW=16H,CLK,GATE,OUT,LSB=5,5,4,2,5,5,4,CR=5,2,5,计数初值为奇数时的波形,CRCE,CRCE,CRCE,5、方式4软件触发选通 时序图,8253方式4,CR=2,CRCE,CW=18H,CLK,GATE,OUT,LSB=2,2
12、,1,0,2,1,0,0,CRCE,CR=2,LSB=2,6、方式5硬件触发选通 时序图,8253方式5,1,2,CW=1AH,CLK,GATE,OUT,LSB=3,3,0 3,3,3,2,CR=3,7、各种工作方式特点小结 方式0:写入控制字后,OUT即变低,计数结束后,OUT由低变高;方式1 5:写入控制字后,OUT均变高。方式0、1和4:计数初值装进计数器后,仅计数一次;方式2、3和5:计数值为0后,自动将计数初值装进实际计数器。启动方式:方式0、4为软件启动;方式1、5为硬件启动;方式2、3为软件、硬件均可启动,门控信号GATE的控制功能,四、8253与系统的连接,应用步骤:与系统连接
13、 设置工作方式 置计数初值 两种功能:定时功能应用 计数功能应用,8-2 8253的应用举例,软件程序设计,硬件电路设计,【例1】用8253产生各种定时波形。在某个以8086为CPU的系统中使用了一块8253芯片,通道的基地址为310H,所用的时钟脉冲频率为1MHz。要求3个计数通道分别完成以下功能:(1)通道0工作于方式3,输出频率为2kHz的方波;(2)通道1产生宽度为480us的单脉冲;(3)通道2用硬件方式触发,输出单脉冲,时间常数为26。,一、8253定时功能举例,分析:8253端口地址 因8253基地址为310H,所以通道03、控制端口地址分别为310H,312H,314,316H
14、。,硬件电路设计,工作方式选择及初值计算 通道0工作于方式3,计数初值为N0=1MHz/2kHz=500。通道1工作在方式1,计数初值为N1=480s/1s=480。通道2工作在方式5,计数初值为N2=26。,1)通道0初始化程序 MOV DX,316H;控制口地址 MOV AL,00110111B;通道0控制字 OUT DX,AL MOV DX,310H;通道0地址 MOV AL,00H;先写低字节 OUT DX,AL MOV AL,05H;后写高字节 OUT DX,AL,初始化程序,2)通道1初始化程序 MOV DX,316H;控制口地址 MOV AL,01110011B;通道1控制字 O
15、UT DX,AL MOV DX,312H;通道1口地址 MOV AL,80H;先写低字节 OUT DX,AL MOV AL,04H;后写高字节 OUT DX,AL,初始化程序,3)通道2初始化程序 MOV DX,316H MOV AL,10011011B;通道2控制字 OUT DX,AL MOV DX,314H;通道2地址 MOV AL,26H;只写入低字节 OUT DX,AL,初始化程序,【例2】利用8253控制LED的点亮或熄灭。要求:循环点亮10秒钟后再让它熄灭10秒钟(周期为20秒),设计接口电路并编程实现。这里8253的各端口地址为81H,83H,85H和87H,时钟信号频率为2MH
16、z。分析:总体思路 对8253编程,输出周期为20秒的方波信号,就能使LED交替亮灭。,时间常数计算 输出频率:(1/20)Hz 时间常数:2M/(1/20)=40M 一个通道的计数初值最多为65536,所以采用多通道级联的方法实现。让通道0和通道1都工作在方式3,通道1的CLK端接通道0的OUT。只要满足两个计数初值的乘积为N0*N1=40M即可,所以通道0的计数初值若为:5000;则通道1的则为:8000。,硬件电路设计 这种设计加上适当的驱动电路后,便可以用在交通红绿灯控制和灯塔等场合。,8253的初始化程序 MOV AL,00110111B;通道0 方式3 BCD计数 OUT 87H,
17、AL MOV AL,00H OUT 81H,AL MOV AL,50H OUT 81H,AL MOV AL,01110111B;通道1 方式3 BCD计数 OUT 87H,AL MOV AL,00H OUT 83H,AL MOV AL,80H OUT 83H,AL,【例3】利用8253设计接口电路,对某工程生产线上的产品的数量进行统计。硬件电路设计,二、8253计数功能举例,光电晶体管,工作原理 无工件通过时,光电晶体管导通,集电极为低电平,经74LS14整形后送到CLK1端;有工件通过时,光电晶体管截止,集电极为高,整形后送到CLK1端,工件通过后又变为低。每通过一个工件CLK1端得到一个正
18、脉冲信号,利用8253对脉冲进行计数,即可得到工件的个数。这种计数方案也可以用于其他场合,如:统计在高速公路上行驶的车辆数,进入工厂的人数。,编程思路 选择计数器1工作在方式0,二进制计数。若选取计数初值n499,则经过500个脉冲OUT1端输出一个正跳变。向CPU发出一次中断请求(或作为CPU查询的状态信号),表示计满500个,在程序中使工件总数加上500。同时由程序将计数初值499再装入计数器1,继续进行计数。,8253的初始化程序 设8253的4个端口地址:F0H,F2H,F4H和F6H,则初始化程序为:MOV AL,01110000B OUT 0F6H,AL MOV AX,499 OU
19、T 0F2H,AL MOV AL,AH OUT 0F2H,AL,8253计数值的读取 利用指令读取8253的当前计数值,但由于读取计数值时计数过程还在进行,其数值不稳定,导致读取的数据错误的。为防止这种情况发生,可采取下面两种方法:计数器停止计数。关闭CLK脉冲或使GATE信号变为低,用IN指令读出计数值。缺点是正常的计数过程被干扰。飞读。在计数的过程中读取数据。先对8253写入一个控制字(RL1、RL0为00),将当前计数值锁存到输出锁存器,再用IN指令读取输出锁存器的值。,上例中若求已计工件件数,可执行下面的程序:MOV AL,01000000B;锁存计数器1控制字 OUT 0F6H,AL;发锁存命令 IN AL,0F2H;读低8位 MOV AH,AL IN AL,0F2H;读高8位 XCHG AH,AL;计数值在AX中 MOV BX,500 SUB BX,AX;已计工件数在BX中,小结,主要内容:8253内部结构:3个16位计数器通道和1个控制寄存器。8253各计数器的初始化编程:写控制字和计数初值。计数器的6种工作方式特点:启动方式、输出波形、是否可重复计数等 8253的计数、定时功能的应用 重点难点 8253的各种工作方式的原理及其应用,