8253微机原理
微机原理 可编程计数器定时器8253及应用
第八章 可编程计数器/定时器8253及应用 8-1 8253工作原理
一、8253的内部结构与引脚信号 二、8253的初始化编程
三、8253的工作方式
四、8253与系统的连接
8-2 8253的应用举例
一、8253定时功能举例 二、8253计数功能举例
1
第八章
定时/计数技术概述
计算机中常用到定时功能,如:动态RAM刷新、
第八章
二、8253的初始化编程
8253的初始化编程按顺序分两步完成:
1、写入控制字
2、写入计数初值
初始化编程的几点说明: 对3个计数通道的初始化编程没有先后顺序
若是16位数,必须用两条OUT指令来完成,且先送低8
位数据,后送高8位数据。 若计数初值为0时,要分成两次写入。0在二进制计数
18
第八章
8253方式3
4、方式3——方波发生器
时序图
计数初值为偶数时的波形
CW=16H WR CR=4 CLK GATE LSB=4
OUT
CRCE 4
CRCE 2
19
CRCE
2 4
CRCE 2 4
CRCE 2 4
4
第八章
8253方式3 计数初值为奇数时的波形
CW=16H WR
LSB=5 CR=5
CLK GATE
OUT CRCE 5 4 CRCE 2 5 CRCE CRCE 4 2 5
2
5
20
第八章
8253方式4
5、方式4——软件触发选通
时序图
CW=18H WR
LSB=2 CR=2
LSB=2 CR=2
CLK GATE OUT CRCE 2 1 CRCE 0 2 1 0 0
微机原理8253
OUT
1、 结构
8位双向三态。用于与CPU交换信息。 • 初始化时,CPU向其写入命令字等, 计数值; • CPU读取计数值。
计数器/ 数据总线 缓冲器
接收来自系统总线 的控制信号,以产 生控制整个芯片工 作的控制信号 计数器 0号 定时器通 道。 由16位的 可预置值 的减法计
读/ 写 逻辑
计数器 1号
数器构成。
初始化时,由CPU 写入控制字以决定 某通道的工作方式。
控制字 寄存器
计数器 2号
端口选择
8253有3个独立的计数器(计数通道),其内部结构完全 相同,如图3.3所示。 图3.3表示计数器由16位计数初值寄存器、减1计数器和当 前计数值锁存器组成。
8253无论作定时器用,还是作计数器用,其内部操 作完全相同,区别只在于前者是由计数脉冲(间隔不一 定相同)进行减1计数,而后者是由周期一定的时钟脉 冲作减1计数。作计数器用时,要求计数的次数可直接 作为计数初值预值到减1计数器;作定时器用时,计数 初值即定时系数应根据要求定时的时间和时钟脉冲周期 进行如下换算才能得到: 定时系数=要求定时的时间/时钟脉冲周期 计数初值与输入时钟(CLK)频率及输出波形(OUT) 频率之间的关系为 Ci= CLK/OUT 或 TC=CLK/OUT 利用关系式,可以计算出当给定CLK频率,要求所输出 的波形的频率为某值时的计数初值。
一、基本概念
一、定时/计数 在计算机系统、工业控制领域、乃至日常生活中,都存在定时、计 时和计数问题,尤其是计算机系统中的定时技术特别重要。 1.定时 定时和计时是最常见和最普遍的问题,一天24小时的许晓称为日时 钟。 2.计数 计数使用得更多。 3.定时与计数的关系 计时的本质就是计数,只不过这里的“数”的单位是时间单位。
微机原理与应用教学资料第八章 8253
fclk=2MHZ 据题意 TOUT=20s fout=1/20 计数初值N=2×106×20=4×107>65536
∴级联
取N1=5000,N2=8000
控制字 00110101 (35H,通道0)
M/IO A7~A0
若二进制计数
N1=1388H
I/0译码 A1 A2
CS GATE0 GATE1
A1 CLK0 A0 OUT0
2、写入计数初值 A1A0=00,01,10
初值 8位:一条输出指令
16位:两条输出指令 先送低8位初值后送高8位初
值
例:选择0#通道,工作方式3,计数初值2354H,BCD计数方式
8253端口地址为40H~46H
D7 D6 D5 D4 D3 D2 D1 D0
0
0
1
1
×1
1
1
通道0
|
|
|
先读写低8位,后读写高8位
c) A1、A0:端口选择信号,接8086CPU的A2、A1地址线 若为8088CPU,8位数据线,则接系统的A1、A0(实验用电路)
00:计数器0
01:
1
∴8253需要4个端口地址
10:
2
11:控制器R
电气学院学习部资料库
4
例:8253的基地址为FOH(11110000B)
则:计数器0:FOH;计数器1:F2H;计数器2:F4H;控制寄 存器:F6H
通道1:方式3 方波发生器 通道GATE1由8255A的PA0控制, 当GATE1为高电平,输出方波,扬声器响。
在中断服务程序中控制GATE高电平的时间,软件延时
②控制字设置
通道0:0 0 0 1 0 1 0 1 通道1:0 1 1 1 0 1 1 1 主程序:MOV AL ,00010101B
微机原理-8253
MOV AL,0B5H; OUT 07H,AL; MOV AL,00H; OUT 06H,AL; MOV AL,05H; OUT 06H,AL;
精品资料
方式(fāngshì) 3 —— 方波发生器
• 方式3与方式2的工作类似,输出(shūchū)固定频率的 脉冲。 • 计数器具有“初值自动重装”的功能。 • 工作特点如下: • 当计数值为 偶数 时,则输出(shūchū)对称方波。 • 前 N/2 计数期间 输出(shūchū)高电平,即 OUT = 1; • 后 N / 2 计数期间输出(shūchū)低电平,即OUT = 0; • 当计数值为 奇数 时,前 (N+1) / 2 计数期间, • 输出(shūchū)高电平,即 OUT = 1, • 后(N-1) / 2 计数期间输出(shūchū)低电平,即 OUT = 0 。
精品资料
方式0 —— 工作(gōngzuò)方式的特点
1、写入控制字后,OUT= 0 为低电平,只有当 GATE = 1 时, CLK 端来一个计数脉冲,计数器才进行减一计数。 当计数值减为 0 时,计数全过程结束,计数器停止计数, OUT =1为高电平。
2、如果使计数器重新开始计数,需再次写入计数字值,当新计数值 写入后, OUT 端电平才能由高变低。
•
OUT =1 不变。
•
当计数值减为1 时,OUT = 0 ,经过一个 CLK时钟
•
周期后, 计数器自动启动,继续重复计数过程。
• OUT =0 的时间是一个 CLK 周期。
精品资料
方式(fāngshì)2 ——频率发生器
2、在计数过程中,可以改变计数值。如果在计数过程中, 重新写入某一计数值,在写入新计数值后,不影响正在 进行的计数过程,待计数过程完成后,在下一个计数过 程开始时,按新的计数值,重新开始作减一计数。
河北专接本微机原理8253工作方式
河北专接本微机原理8253工作方式8253是一种微机原理的专接本技术,主要用于计时和计数应用。
它是由Intel公司设计的,并且被广泛应用于微处理器系统中。
本文将详细介绍8253的工作方式。
8253由3个计数通道组成,每个通道都具有一个16位的计数器寄存器,一个计数器控制寄存器和计数器输出端口。
每个通道都可以执行不同的计数功能,并且可以通过设置对应的控制寄存器来配置。
8253的主要工作模式有3种:方波发生器模式、比率发生器模式和计时器模式。
下面分别介绍这3种模式的工作方式。
1.方波发生器模式方波发生器模式下,计数器工作在一个循环计数的模式下,并产生一个固定频率的方波信号输出。
通过设置计数器控制寄存器,可以配置方波的频率和占空比。
具体的工作流程如下:-设置计数器控制寄存器,确定计数方式为方波发生器模式,并设置计数器的工作频率和占空比。
-启动计数器,计数器开始累加计数。
-当计数器的值达到设定的计数上限时,计数器会自动清零并继续计数。
-每次计数达到上限时,计数器输出端口会产生一次电平翻转,从而产生方波信号。
2.比率发生器模式比率发生器模式下,计数器工作在一个固定的计数上限下,并产生不同的方波信号输出。
通过设置计数器的初始计数值和计数上限,可以实现不同的频率和占空比。
具体的工作流程如下:-设置计数器控制寄存器,确定计数方式为比率发生器模式,并设置计数器的初始计数值和计数上限。
-启动计数器,计数器开始累加计数。
-当计数器的值达到计数上限时,计数器会自动清零,并产生一个电平翻转。
-根据初始计数值和计数上限的设置,可以实现不同频率和占空比的方波信号输出。
3.计时器模式计时器模式下,计数器工作在外部输入时钟的驱动下,并可以测量和记录时间间隔。
具体的工作流程如下:-设置计数器控制寄存器,确定计数方式为计时器模式。
-将外部时钟信号连接到计数器输入端口,计数器开始根据时钟信号进行计数。
-当计数器的值达到计数上限时,计数器会自动清零。
微机原理-8253
8253工作方式特点: 8253工作方式特点: 工作方式特点
方式0 在写入控制字后,输出端即变低,计数结束后, 方式0,在写入控制字后,输出端即变低,计数结束后,输 出端由低变高,常用该输出信号作为中断源。 出端由低变高,常用该输出信号作为中断源。 方式1 用来产生单脉冲。 方式1,用来产生单脉冲。 方式2 用来产生序列负脉冲,每个负脉冲的宽度与CLK脉冲 方式2,用来产生序列负脉冲,每个负脉冲的宽度与CLK脉冲 CLK 的周期相同。 的周期相同。 方式3 用来产生连续的方波。方式2和方式3 方式3,用来产生连续的方波。方式2和方式3都实现对时钟 脉冲进行n分频。 脉冲进行n分频。 方式4和方式5 波形相同,都在计数器回0 方式4和方式5的波形相同,都在计数器回0后,从OUT端输出 OUT端输出 一个负脉冲,其宽度等于一个时钟周期。 一个负脉冲,其宽度等于一个时钟周期。 方式0 方式0、1和4,计数初值装进计数器后,仅一次有效。方式2,3 计数初值装进计数器后,仅一次有效。方式2 在减1计数到0值后,8253会自动将计数值重装进计数器 会自动将计数值重装进计数器。 和5,在减1计数到0值后,8253会自动将计数值重装进计数器。
可编程定时器/计数器8253
8253可编程定时器 计数器的主要性能: 可编程定时器/计数器的主要性能 可编程定时器 计数器的主要性能: 个独立的16位计数器 有3个独立的 位计数器 个独立的 工作方式可编程控制 计数脉冲频率0~2MHz 计数脉冲频率 可以按二进制或BCD码计数 可以按二进制或BCD码计数 使用单一+5V电源 电源 使用单一
方式2:频率发生器(n分频器)
CLK
WR
GATE OUT
n=4
4
3 2
1 0 4 3
微机原理第09章 8253-2(完)
方式3 方波发生器
方式3
WR CLK 4
GATE
4 3 2 1 0 4 3 2 1 0 4 3 2 1 0 4 3 2波频率
方式4 软件触发选通信号
方式4 WR CLK GATE 4
4 3 2 1 0
OUT
方式5 硬件触发选通信号
方式5 WR 4
CLK GATE
3
2
1
0
④ 计 数 ⑥初 ⑤② ③ 值① 计送 计写 硬 数减 写 数入 入 件 结 1计 过 控 启 束计 程数 制 动 初 数 字 值 寄 存 器
方式2 频率发生器(分频器)
方式2 4
WR CLK
GATE 4 3 2 1 0 4 3 2 1 0 4 3 2 1 0 4 3 2 1 0
OUT
计数初值=时钟脉冲频率/负脉冲发生频率
向控制字端口地址:写入锁存命令 从计数器端口地址:读取锁存的当前计数值
读取计数值,要注意读写格式和计数数制
例1:要求计数器0工作于方式3,输出方波的频率为 2KHz,计数脉冲的频率为2.5MHz,采用二进制计数,试 写出初始化程序段。
1. 8253的端口地址为:80H,81H,82H,83H。 2. 计数初值计算:TC = 2.5MHz/2KHz=1250 3. 8253的方式控制字为: 00 11 011 0 4. 初始化程序段: MOV OUT MOV OUT MOV OUT AL,00110110B 83H,AL AX, 1250 80H,AL AL, AH 80H,AL
D3 D2
D1
D0
计数器
00: 计数器0 01: 计数器1 10: 计数器2 11: 无意义
读写格式
00: 锁存计数值 01: 只读写低8位 10: 只读写高8位 11: 先读写低8位 后读写高8位
微机原理课_8253
8.1 概述
1、应用场合
在微机系统中,要求对外部信号进行计数 或要求对时间进行精确定时----计数/定时器. 计数由外部脉冲信号提供,当达到设定的计数 值时,输出一个电平信号,告知外部设备已经计 满。定时时间基准由8086内部时钟源提供,经 定时钟分频后得到所需的时间信号,当定时时 间到后也输出一个电平信号,告知外部设备定 时时间到。
8253初始化编程要求
1、8253三个端口有各自独立的地址,控制字分别对
各端口的工作方式进行设置。 2、对某一个端口设置初值时,先设置控制字 3、设置初值时,要符合D5、D4的规定,分别输入计 数值。(16位计数值要用两条指令写入计数值) 4、锁存(D5D4=00)的目的是:在CPU读取计数值前 先用锁存命令锁存减1计数器的当前值,否则得不到 正确的结果,CPU取走数据后,锁存功能自动失锁 5、编程顺序:先写入控制字到控制寄存器,然后写 入计数初值到所确定的计数器端口!!!
2、定时与计数的三种方式
1) 软件定时: 利用 CPU 每执行一条指令都需要几个固定的 指令周期的原理,因此执行一个程序段就需要一 定的时间,运用软件编程的方式,通过改变指令 执行的循环次数就可以控制定时时间,由于它占 用了CPU,因而降低了CPU的利用率。 例: MOV CX,1000H DEALY: MOV BX,1000H LOOP DEALY
15 14 13
CLK1 GATE 1 OUT1
计数器
微机原理与接口技术_第7章8253
§7-1 8253的工作原理 ——8253的内部结构和引脚信号
然后,开始递减计数。即每输入一个时钟脉冲,计数
器的值减1,当计数器的值减为0时,便从OUT引脚输出 一个信号。输出信号的波形主要由工作方式决定,同 时还受到从外部加到GATE引脚上的门控信号控制,它 决定是否允许计数。 当用8253作外部事件计数器时,在CLK脚上所加的计 数脉冲是由外部事件产生的,这些脉冲的间隔可以是 不相等的。 如果要用它作定时器,则CLK引脚上应输入精确的时 钟脉冲。这时,8253所能实现的定时时间,决定于计 数脉冲的频率和计数器的初值,即 定时时间=时钟脉冲周期tc×预臵的计数初值n
16
§7-1 8253的工作原理 ——8253的内部结构和引脚信号 ③引脚 8253的3个计数器都各有3个引脚,它们是:
CLK0~CLK2:计数器0~2的输入时钟脉冲从这里输
入。频率不能大于2MHz。
OUT0~OUT2:计数器0~2的输出端。
GATE0~GATE2:计数器0~2的门控脉冲输入端。
4
第七章 可编程计数器/定时器8253及其应用 ——概述 2. 不可编程的硬件定时 555芯片是一种常用的不可编程器件,加上外接电阻和电 容就能构成定时电路。这种定时电路结构简单,价格 便宜,通过改变电阻或电容值,可以在一定的定时范 围内改变定时时间。但这种电路在硬件已连接好的情 况下,定时时间和范围就不能由程序来控制和改变, 而且定时精度也不高。 3. 可编程的硬件定时 ①可编程定时器/计数器电路利用硬件电路和中断 方法控制定时,定时时间和范围完全由软件来确 定和改变,并由微处理器的时钟信号提供时间基 准,这种时钟信号由晶体振荡器产生,故计时精
12
§7-1 8253的工作原理 ——8253的内部结构和引脚信号 8253输入信号组合的功能表
微机原理第七章 计数器定时器8253
三、Intel 8253
1. 芯片引腿 2. 编程结构 3. 结构组成 4. 控制寄存器格式 5. 编程命令 6. 工作模式
D7 D6 D5 D4 D3 D2 D1 D0 CLK0 OUT0
GATE0 GND
1
24
2
23
3
22
4
21
8253 5
20
6
19
7
18
8
17
9
16
10
15
11
14
12
13
D0---BCD位,用来设置装入CR计数值的格式。 0——计数值为二进制格式 1——计数值为BCD码格式
一作为计数器,在设置好计数初值后,便开 始减1计数,减到“0”时,输出一个信号;
二作为定时器,在设置好定时常数后,便进 行减1计数,并按定时常数不断地输出 为时 钟周期整数倍的定时间隔。
计数器与定时器的差别在于:计数器计 数到零时便输出一个信号并结束;而定时器 会不断地产生信号。
计数器与定时器的共同点在于: 它们的工作过程没有根本区别,都是基于
3. 结构组成
D7~D0
数据总线 缓冲器
计数器 0
CKL0 GATE0 OUT0
RD
CKL1
WR A0
读/写控制逻 辑电路
A1
内 部 总
计数器 1
GATE1 OUT1
CS
线
控制 寄存器
计数器 2
CKL2 GATE2 OUT2
8253的芯片引脚及结构组成
① 计数器0,计数器1,计数器2 ② 数据总线缓冲器
功能: 往控制寄存器设置控制字 往计数器设置初值 从计数器读取计数值 ③控制寄存器 ④读/写逻辑电路
8253工作原理解析
8253工作原理解析8253是Intel公司推出的可编程定时/计数器芯片,主要用于微处理器系统的定时和计数功能。
它的工作原理是通过将时钟源与内部寄存器和计数器进行连接,并根据编程输入信号来控制计数和定时过程。
下面,我们将从时钟源、内部寄存器和计数器以及编程输入信号三个方面对8253的工作原理进行解析。
首先,时钟源是8253工作的基础。
该芯片可以接受外部的单脉冲信号作为时钟源,也可以使用芯片内部的时钟发生器来产生时钟信号。
时钟信号是8253芯片的主要驱动信号,它通过时钟输入端进入芯片内部的计数电路。
其次,8253芯片内部包含有3个独立的16位计数器。
这些计数器可以独立地工作,同时具有计数和定时功能。
每个计数器都有一个计数寄存器和一个输出端。
计数寄存器用于存储计数器的初值,并根据计时或计数的要求递减或递增。
输出端用于将计数结果输出给微处理器或其他外部设备。
计数器的计数和定时方式可以通过编程输入信号进行设置和控制。
最后,编程输入信号是8253芯片的控制信号,用于对计数器进行编程。
它可以由微处理器通过编程方式输入,以控制计数器的工作方式。
编程输入信号主要包括计数器选择信号、计数方式信号和计数值信号。
计数器选择信号用于选择要编程的计数器,将编程输入信号应用于对应的计数器。
计数方式信号用于设置计数器的计数方式,可以选择连续计数、单次计数、定时计数等方式。
计数值信号用于设置计数器的初值或定时值,根据计数或定时方式的不同,计数值信号的含义也不同。
总体来说,8253芯片的工作原理是将时钟源与内部寄存器和计数器相连,根据编程输入信号的设置,控制计数器的计数和定时过程。
通过编程方式,可以灵活地配置和控制8253芯片的功能,实现不同的计时和计数需求。
第7章8253微机原理及应用
(MODE 3) CLOCK
4 3 2 1 0(4) 3 2 1 0(4) 3 2 1 0
OUTPUT
n=4
n=4
n=3
OUTPUT 0(5) 4 3 2 1 0(5) 4 3 2 1 0(5) n=5
OUTPUT n=4
4 3 2 1 0(4) 3 2 1 0
GATE (RESET)
– 选通输入(门控输入)GATE——用于启动或禁止计数器的 操作,以使计数器 和计测对象同步。
• 每个计数器中有四个寄存器;
– ①控制寄存器——初始化时,将控制字寄存器 中的内容写 入该寄存器;
– ②计数初值寄存器——初始化时写入该计数器的初始 值;
– ③减法计数寄存器——计数初值由计数初值寄存器送人减 法计数寄存器,当 计数输入端输入一个计数脉冲时,减法 计数寄存器内容减1,当减到零时,输出 端输出相应信号表 示计数结束。
方式4—软件触发选通(启动计数原理类似于方式0)
• 在这种方式下,当写入控制字后,输出为高(原为高则保持为高,原为 低则变为高)。当写入计数值后立即开始计数(相当于软件启动),当 计数到0后,输出变低,经过一个输入时钟周期,输出又变高,计数器停 止计数。这种方式计数也是一次性的,只有在输入新的计数值后,才能 开始新的计数。
– (4)每个计数器有6种工作方式,可由程序 设置和改变。
– (5)所有的输入输出引脚电平都与TTL电平 兼容。
8253的结构和引脚
• 三个计数器中每一个都有三条信号线;
– 计数输入CLK——用于输入定时基准脉冲或计数脉冲;
– 输出信号OUT——以相应的电平指示计数的完成,或输 出脉冲波形; ·
二、8253在IBM-PC/XT机中的应用
8253微机原理
00010000
特点: 1. 计数器只计一遍。当计数到 0 时,并不恢复计数初值,不开始重新 计数,且输出一直保持为高。只有在写入下一个计数值时,OUT 变低,开始新的计数。
特点: 2. 在计数过程中,可由门控信号GATE控制暂停。GATE=0, 计数暂停, GATE变高后,接着计数。
特点: 3. 在计数过程中,可改变计数值。在写入新的计数之后,计数器按新 的值重新开始计数。
开始计数),OUT输出端变低。在整个计数过程中,OUT 都维持为低,直到计数 为 0 时,输出变为高,输出一个单脉冲。
特点: 1. 若设置的计数值为N,则输出的单脉冲宽度即为N个输入脉冲间隔。 2. 当计数到 0 后,可再次由外部触发启动,输出一个同样宽度的 单拍脉冲,而不用再次送计数值。
特点: 3. 在计数过程中,外部可发门控信号进行再触发,在触发脉冲上升沿 后的下一个CLK脉冲的下降沿,计数器将重新开始工作。
0
0 1
1
1 ×
0
0 ×
1
1 ×
0
1 ×
8253的控制字
◆ 8253控制字可以选择计数器、工作方式、计数数制( 2#或 10#——BCD码),以及计数器的读/写方法等。 ◆ 8253控制字格式(8位) :
D7 SC1 D6 SC0 D5 RW1 D4 RW0 D3 M2 D2 M1 D1 M0 D0 BCD
8253操作的控制逻辑
CS 0 0 0 0 0 0 RD 0 0 0 0 1 1 WR 1 1 1 1 0 0 A1 0 0 1 1 0 0 A0 0 1 0 1 0 1 操作说明
计数器0→数据总线 计数器1→数据总线 计数器2→数据总线 非法状态 数据总线→计数器0 数据总线→计数器1 数据总线→计数器2 数据总线→控制寄存器 D7~D0呈高阻状态
理工大学《微机原理与应用第8章 8253及其应用》课件
下面我们来讨论一下8253与8086 CPU的 连接问题以及端口地址的选择。
表8-1 8253输入信号组合的功能表
CS RD WR A1A0
功能
0 1 0 0 0 写入计数器0
0 1 0 0 1 写入计数器1 0 1 0 1 0 写入计数器2 0 1 0 1 1 写入控制字寄存器
0 0 1 0 0 读计数器0
★计执数输行初出部值锁件寄存实存器际器用上、来是计锁一数存个器计1执数6位行器的部执减件行法和部计输件 数 的 出器 值 锁,存它必器的要都起时是C1始6P位值U寄就可存是对器初它,值执它寄行们存读均器操可的作分值,成,以 该 了 高值 解 8位可某和由个低程时8位序刻两设 计个置 数部。 器分的。瞬间值。
11:先读/写计数器低字节,后读/写高字节
图8-3 8253控制字格式
二、初始化编程步骤和门控信号的功能
对8253芯片进行初始化编程时,需按下 列步骤进行: (1)写入控制字
用输出指令向控制字寄存器写入一个控 制字,以选定计数器通道,规定计数器的工 作方式和计数格式。写入控制字还起到复位 作用,使输出端OUT变为规定的初始状态, 并使计数器清0。
的输入信号,经组合后形成控制信号,对 各部分操作进行控制。可接收的信号有:
(((1243)))RCWADSR1片读写A选信0信端信号号口号,,选, 低低择低 电电信电 平平号平 有有。有 效效在效 。。8, 当2当5由R3WD内地R为为部址低低有总电电3线个平平 经 时计时I,数,/O表器表端示通示口C道C译PP(U码U正0正电~在2在路)读将产和取计生一所数。个选初只控定值有制的写当字计入C寄数S所为存器选低器通定电端道的平口。 时 中当计, 的A数1内C通AP容0U道=。才0中0能时或对,将8选控25择制3进通字行道写读0入;写控A操制1A作字0。=寄01存时器,中选。 择通道1;A1A0=10时,选择通道2;A1A0=11 时,选中控制字寄存器端口。
8253的工作原理及应用
8253的工作原理及应用一、工作原理8253是一种常见的计时/计数芯片,它能够完成各种定时和计数功能。
它采用了三个计数器,分别为计数器0、计数器1和计数器2。
每个计数器可以独立工作,同时也可以与其他计数器进行协同工作。
具体的工作原理如下:1.计数器的基本工作原理是将外部时钟信号分频后输出,根据计数器的工作模式,可以输出不同的周期信号。
2.8253有三个计数器,计数器0可以设置工作模式,计数器1和计数器2可以由计数器0通过控制字来选择工作模式。
3.通过控制字可以设置计数器的工作模式,比如设置为定时器工作模式、内部触发工作模式、软件触发工作模式等等。
4.计数器工作的时候,是通过输入控制字来设置计数器的初始值,然后按照设定的模式进行计数,当计数到达设定的值时,会触发相应的事件,例如输出一个脉冲信号或者产生一个中断。
二、应用领域8253芯片在计算机系统中有广泛的应用,主要包括以下几个方面:1.定时器功能:8253芯片可以实现定时器的功能,通过改变控制字设置的工作模式和初始值,可以产生定时脉冲信号,精确地控制计时间隔。
这在操作系统中非常常见,可以用于定时器中断、延时等。
此外,它还可以用于工业自动化领域中的精确控制和同步任务。
2.计数器功能:8253芯片也可以作为计数器使用。
例如,在测量系统中,可以通过外部输入信号的脉冲数量来进行计数,并配合计时功能实现测量和统计。
3.PWM信号生成:8253芯片可以实现PWM(脉宽调制)信号的生成。
通过改变初始值和周期,可以控制PWM信号的占空比,实现对电机速度、光强等参数的控制。
4.音频处理:8253芯片中的计数器可以用于实现音频处理。
通过设定计数器的频率,可以控制音频信号的采样率,从而实现音频的录制和播放。
5.高速脉冲生成:8253芯片可以产生高速脉冲,用于直流电机控制、步进电机控制等应用场景中。
三、优势与不足8253芯片具有以下几个优点:•多功能性:8253芯片具有丰富的工作模式,可以根据不同的需求灵活地配置和应用。
微机原理第8章8253及其应用
WR
CW
OUT
N=4
4
2
4
2
GATE
4
2
4
2
8253的工作原理
三、 8253的工作方式
5. 方式4:软件触发选通(P313)
N值写入后,如Gate为高,则下一个CLK开始计数,相当于软件启动;
GATE=“1”,允许计数,GATE=“0”,禁止计数,因此,要做到软件启动,必须使GATE=“1”;
若计数值为N,则输出脉冲宽度为N*CLK;
计数到0,可由GATE上升沿再次触发,输出一个脉冲,不需重新赋值;
若重新开始计数;
CLK
WR
CW
OUT
N=3
3
2
1
GATE
3
若计数过程中,CPU改变计数值,但计数过程不受影响,再次触发后,按新值重新计数。
通道的地址分别为310H, 312H, 314H, 316H。
1)计数器0:方式3,OUT0输出方波 N0= fCLK/fOUT = 1MHz /2KHz =106/2 103 = 500
2)计数器1:方式1,OUT1输出单脉冲 N1= TOUT/TCLK = 480 s / 1 s = 480
计数过程中改变计数值,若没有GATE的触发,不影响计数过程,当计数到“0”后,若有GATE触发,则按新的计数值计数.
CLK
WR
CW
特点:
OUT
N=5
4
3
2
1
GATE
0
5
5
5
8253的工作原理
三、8253的工作方式
6种工作方式主要区别: 8253的工作原理 OUT输出波形不同。 启动计数器的触发方式不同。 计数过程中门控信号GATE对计数操作的影响不同。 有的工作方式具备“初值自动重装”的功能。初值自动重装的功能是:当计数值减到规定的数值(通常为0)后,计数初值将会自动地重新装入计数器。
8253工作原理
7.3 可编程串行接口芯片8251A
7.3.1 8251A的基本性能 8251A是可编程的串行通信接口芯片,基本性能如下: (1)两种工作方式。同步方式和异步方式。同步方式下, 波特率为0~64K;异步方式下,波特率为0~19.2K。 (2)同步方式下的格式。每个字符可以用5、6、7或8位来 表示,并且内部能自动检测同步字符,从而实现同步。除此 之外,8251A也允许同步方式下增加奇/偶校验位进行校验。 (3)异步方式下的格式。每个字符也可以用5、6、7或8位 来表示,时钟频率为传输波特率的1、16或64倍,用1位作为 奇/偶校验,1个启动位,并能根据编程为每个数据增加1个 、1.5个或2个停止位。可以检查假启动位,自动检测和处理 终止字符。 (4)全双工的工作方式。其内部提供具有双缓冲器的发送 器和接收器。 (5)提供出错检测。具有奇偶、溢出和帧错误三种校验电 路。
(5)方式3:方波速率发生器。
特点:与方式2类似,只是进行减2操作,直到0时, OUT变低 ,并自动重新写入计数值减2操作,直到0时, OUT变高。一 般作为方波发生器使用。
(6)方式4:软件触发的选通信号发生器。
特点:写入控制字寄存器后,输出OUT就变高;GATE为高计数,为低停止计 数;不自动重新计数,需要重新将计数值写入计数器后开始计数;计数到0时 ,OUT变为低,经过一个CLK周期 后变为高。不自动重新计数,只有重新软 件写入计数值,同时GATE为高时开始计数。
微机原理_定时计数器8253
工作方式举例:方式2 二、工作方式举例:方式2
GATE门控 门控 信号
写入计 数初值 写入控 制字 WR GATE CLK OUT
方式2 方式2的工作特点是 计数,输出为持续不 断的周期信号
CLK 输入
计数脉冲 软件写入计数器启动 OUT 可预置初值计数器 计数,输出为持续不 计数, 输出
设计数初值为3 设计数初值为3
—— 启动 启动 启动 —— 启动
允许 —— 允许 允许 允许 ——
三、设置工作方式和计数值 对8253设置工作方式和设置计数值是连续 进行的。 步骤是:
1、对控制端口写:设置工作方式及计数值格式 2、对计数端口写:计数值低8位(可选) 3、对计数端口写:计数值高8位(可选)
控制字格式:
D7 SC1
1.19MHz / 533H = 900Hz
如果需要自定义频率值为263,则可以: MOV DX, 12H MOV AX, 3480H MOV SI, 263 DIV SI ;在AX中就得到了 计数值
音阶和频率的对应关系: 音符 1 2 3 4 5 6 7 1 频率 262 294 330 347 392 440 523 524 音符 1 2 3 4 5 6 7 1 频率 524 588 660 698 784 880 988 1048
8088
译码
A1 A0 AD7 | AD0 /WR /RD
8253
/CS A1 A0 D7 | D0 /WR /RD CLK0 OUT0 GATE0
10HZ频率 发生器
+5V
+5V +5V
0 1 2 3 4 5
定时计数器0
程序段如下
MOV OUT MOV OUT MOV OUT HLT AL , 0011 0000B 43H , AL ;写控制字 AL , 50 40H, AL ; 写计数初值低8位 AL , 0 40H, AL ; 写计数初值低8位
8253的工作原理
8253的工作原理
8253是Intel 8253A/8254计时器芯片的型号,它是一种具有计数和计时功能的编程设备。
该芯片可在微处理器系统中生成多种定时信号和测量时间间隔。
8253芯片包含三个16位计数器,分别称为计时/计数器0(Timer/Counter 0)、计数器1(Counter 1)和计数器2(Counter 2)。
每个计数器都可以独立地以不同的计数方式和触发方式工作。
其中,计时/计数器0主要用于系统时钟的计时和分频功能。
它可设置为16位二进制计数或BCD(二进制编码十进制)计数,支持多种工作方式。
通过对计时/计数器0进行适当的编程,可以控制系统的时钟频率以及产生各种定时和计数信号。
计数器1和计数器2主要用于通用计数和脉冲计数应用。
它们可以被编程为16位二进制计数或BCD计数,并具有不同的计数方式和触发方式。
这些计数器可以用于计量时间间隔、频率测量、脉冲生成以及其他计数应用。
8253芯片的工作原理是通过编程设置芯片内部寄存器的值来控制其计数操作。
通过读写芯片地址空间中对应的寄存器,可以配置计数器的计数方式、触发方式、初始计数值等。
应用程序可以通过与8253通信,实现所需的定时和计数功能。
总之,8253芯片是通过编程设置寄存器的值来控制其计数和
计时操作的,它能够为微处理器系统生成多种定时信号和测量时间间隔的功能。
微机原理GSWJ5-8253 0
INTREEUP3: : ADD INTCNT,01H CALL 显示中断次数 CMP INTCNT, 05H JNA INTRE2 CALL 显示 ‘good’ ;DISP:good 结束 INTRE2: MOV AL, 20H MOV DX, INTPORT1 OUT DX, AL IRET
格式:D7 D6 D5 D4 D3 D2 SC1 SC0 RL1 RL0 M2 M1
D1 D0
写入控制字
写入计数初值
M0
BCD
2、赋初值
用两种方式 赋值 二进制--范围:1~65536 十进制--范围:1~10000
举例:计数器0为方式0计数,计数初值为100;计数器1
定时1ms,时钟频率为2MHz。编写初始化程序段。 (设8253口地址为40H~43H)
第六章
6.1 概述
计数/定时技术
微机中常用的计时功能有三种:
软件定时 不可编程的硬件定时--如555定时器
可编程的硬件定时--如8253、8254
6.2 可编程计数器/定时器电路--8253
一、8253内部结构和引脚功能 1、8253的内部结构
8253的内部结构如下所示:
可见由数据总线缓冲器、读/写控制逻辑及三个16位 的计数器组成
MOV AL,13H MOV DX,INTPORT1 OUT DX,AL MOV AL,08H MOV DX,INTPORT2 OUT DX,AL MOV AL,09H OUT DX,AL MOV AL,0F7H OUT DX,AL MOV intcnt,01H STI WATING: CALL DISP JMP WATING
;TIME=1
;DISP 8259-1
;装填中断向量 WRINTVER: MOV AX,0H MOV ES,AX MOV DI,002CH LEA AX,INTQ3 STOSW MOV AX,0000h STOSW MOV DI,003CH LEA AX,INTQ7 STOSW MOV AX,0000h STOSW RET
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
特点: 2. GATE信号能使计数过程重新开始。GATE=0,计数停止,当GATE=1后, 计数器将重新装入计数初值,重新开始计数。
特点: 3. 若在计数期间写入新的计数值,并不影响现行计数过程。但若此时收到 GATE信号,则计数器将在下一个CLK脉冲时装入新的计数值并开始计数。
(5) 方式4 —— 软件触发选通
8253的计数初值
◆8253计数初值N的计算: N=CLK输入频率/OUT输出频率 ◆设置计数初值N要符合控制字的计数器位数规定。 若用低位字节,或高位字节计数,8位计数初值一次写。 若用高、低位字节计数,16位计数初值分两次写入,先写 低字节,后写高字节。 ◆计数初值0是计数器所能容纳的最大计数值。
特点: 1. 不用重新设置计数值,计数器能够连续工作,输出固定频率的脉冲。
特点: 2. 计数过程可由门控信号GATE控制。当GATE变低时,暂停计数;在 GATE变高后的下一个CLK脉冲使计数器恢复初值,重新开始计数。
特点: 3. 在计数过程中可以改变计数值,这对正在进行的计数过程没有影响, 但在计数到 1 输出变低后,下一个计数周期,计数器将按新的计数值计数。所 以改变计数值是下次有效的。
例如,(8253端口地址40H~43H) MOV AL,40H ;计数器1的锁存命令 OUT 43H,AL IN AL,41H ;读低8位计数值 MOV CL,AL IN AL,41H ;读高8位计数值 MOV CH,AL ;CX中为读取的16位计数值
8253的读操作编程
8253的工作方式
◆8253有六种工作方式: 方式0──计数结束产生中断 方式1──可重复触发的单稳态(脉冲)触发器 方式2──频率发生器(分频器) 方式3──方波频率发生器 方式4──软件触发选通信号发生器 方式5──硬件(GATE)触发的选通信号发生器 ◆六种工作方式的主要区别: 输出波形不同; 启动计数的触发方式不同; 门控(GATE)信号对计数过程的影响不同; 计数过程中,修改计数初值对计数过程的影响不同。
特点: 4. 8253内部没有中断控制电路,也没有专用的中断请求引线,因此, 若要用于中断,则可用OUT 信号作为中断请求信号,但需要有外接 的中断优先权排队电路与中断向量产生电路。
在PC机中,用 8259A 作中断优先权排队电路与中断向量产生电路。
(2) 方式1 —— 可编程的单拍脉冲
当控制字写入控制字寄存器后,OUT输出保持为高,当CPU写完计数值后, 计数器并不开始计数,直到 GATE 信号启动之后的下一个输入CLK脉冲的下降沿
0
0 1
1
1 ×
0
0 ×
1
1 ×
0
1 ×
8253的控制字
◆ 8253控制字可以选择计数器、工作方式、计数数制( 2#或 10#——BCD码),以及计数器的读/写方法等。 ◆ 8253控制字格式(8位) :
D7 SC1 D6 SC0 D5 RW1 D4 RW0 D3 M2 D2 M1 D1 M0 D0 BCD
门控信号(GATE) 计数状态信号(OUT)
计数初值寄存器
计数值锁存器
◆计数功能实现过程: 在预先设置好计数初值后,便开始对外部给的触发脉冲做减 “1”计数,当计数值减为“0”时,输出一个“计数到”的信 号。
定时/计数器的特点与应用
◆触发计数减1功能的信号必须是触发脉冲信号。 ◆计数器的触发脉冲信号可以是周期恒定,也可以是周期随 意,仅当计数值减到“0”时,输出一个计数结束信号。 ◆定时器的触发脉冲信号必须是周期恒定的时钟信号,在计 数值减到“0”时,输出一个计数为“0”的信号;并把计数 初值自动重新装入,再继续重复做减“1”计数,从而输出 一个恒定的周期性信号。 ◆定时/计数器的应用: 在多任务系统中产生定时中断信号,实现多任务程序的分 时切换; 在定时数据采集,或者实时控制系统中,产生精确的对外 部事件的计数信号,或定时控制信号; 常做一个可编程的波特率(时钟)发生器使用。
微机原理与接口技术
第 6 章 控制器接口
6.3 定时/计数器
6.3.1 定时/计数器工作原理
6.3.2 可编程定时/计数器8253 6.3.3 8253应用例
本节复习题
计数器/定时器工作原理
◆计数器/定时器是一个具有可编程计数功能的专用芯片。 ◆计数器/定时器的结构:
D 7 ~ D0
“写” 减1计数器 “读” D7~ D0 触发脉冲信号(CLK)
在这种方式下,当写入控制字后,输出为高,当写入计数值后立即开始计数。 计数到 0 后,输出变低,经过一个CLK周期,输出又变高,计数器停止计数。这 种计数方式是一次性的,当输入新的计数值后,才能开始新的计数。
特点: 1. CPU写入计数值的下一个CLK脉冲,将计数值装入计数器,再下一个 CLK脉冲开始计数,即在装入计数值后的第 N+1 个脉冲后,才输出一个 负脉冲。
计数器选择
0 0: 计数器0 0 1: 计数器1 1 0: 计数器2 1 1: 无意义
读/写方法
0 0:锁存计数值命令 0 1:只读/写低8位 1 0:只读/写高8位 1 1:读/写16位 ( 先低8位后高8位)
工作方式选择
0 0 0:方式0 0 0 1:方式1 ×1 0:方式2 ×1 1:方式3 1 0 0:方式4 1 0 1:方式5
(4) 方式3 —— 方波频率发生器
同频率发生器,区别在于,方波频率发生器在计数过程中输出一半时间为 高,一半时间为低。即其输出是N(N为计数值)个CLK脉冲的方波。
特点: 1. 若计数值为偶数,在装入计数值后,每个CLK脉冲使计数值减2,当计数 到 0 时,一方面输出改变状态,一方面重新装入计数值开始新的计数。 若计数值N 为奇数,则(N+1)/2个CLK脉冲为高电平,(N-1)/2个CLK脉冲为低电平。
8253操作的控制逻辑
CS 0 0 0 0 0 0 RD 0 0 0 0 1 1 WR 1 1 1 1 0 0 A1 0 0 1 1 0 0 A0 0 1 0 1 0 1 操作说明
计数器0→数据总线 计数器1→数据总线 计数器2→数据总线 非法状态 数据总线→计数器0 数据总线→计数器1 数据总线→计数器2 数据总线→控制寄存器 D7~D0呈高阻状态
8位计数初值0,若做2# 计数值是256(100H),若做10# (BCD码)计数值是100;
16位计数初值0,若做2#计数值是65536(10000H),若做 10#(BCD码)计数值是10000 。
◆读取计数器的当前值,可以动态了解计数情况。 ◆ 8253计数器的读操作有直接读和锁存读两种。 直接读操作:计数输出寄存器随减1计数寄存器一直在动态 变化,直接读得不到稳定值,不太可靠(一般不用)。 锁存读操作:先用锁存命令(控制字D5D4为00)把计数值 锁存到计数输出寄存器,然后再读。当计数值读走后,锁 存功能自动失锁。
00010000
特点: 1. 计数器只计一遍。当计数到 0 时,并不恢复计数初值,不开始重新 计数,且输出一直保持为高。只有在写入下一个计数值时,OUT 变低,开始新的计数。
特点: 2. 在计数过程中,可由门控信号GATE控制暂停。GATE=0, 计数暂停, GATE变高后,接着计数。
特点: 3. 在计数过程中,可改变计数值。在写入新的计数之后,计数器按新 的值重新开始计数。
特点: 4. 在计数过程中,CPU可改变计数初值,这时计数过程不受影响,计
数到 0 后输出为高。若再次触发启动,则计数器将按新的计数值计数。 所以改变计数值是下次有效的。
ቤተ መጻሕፍቲ ባይዱ (3) 方式2 —— 频率发生器
当控制字写入控制字寄存器后,OUT输出为高。在写入计数值后,计数 器将立即自动对输入脉冲 CLK 计数。在计数过程中,OUT一直保持为高, 直到计数器减到 1 时,OUT变低,经过一个CLK后,OUT恢复为高,计数器 重新开始工作。
控制寄存器
D7~D0
数据总线 缓冲器
计数器0
初值寄存器
减1计数器
RD
WR
CS A1 A0
读/写 控制 逻辑
输出锁存器
CLK0 GATE0 OUT0
计数器1 计数器2
CLK1 GATE1 OUT1 CLK2 GATE2 OUT2
(2) 结构
8位双向三态。用于与CPU交换信息。 • 初始化时,CPU向其写入命令字等, 计数值; • CPU读取计数值。
8253的主要功能
Intel 8253 定时/计数器的功能:
◆有3个独立的16位计数器通道,既可以做16位计数器,也 可以做8位计数器使用。
◆每个计数器可以选择 2# 计数,或者10# (BCD码)计数。 ◆每个计数器都可以编程设定6种工作方式之一。 ◆每个计数器最高计数速率可达2.6MHz。
8253的内部结构
数制选择
0:二进制 1:BCD码
2.初始值命令
计数器的初始值可以是8位,也可以是16位。如果是16位,则 要用2条指令来完成计数初值的设定,先写入低8位字节,后写入高 8位字节。如果是8位,在计数器内部全部当成16位的两字节处理, 缺少的字节自动补上0。
3.锁存命令
锁存命令是为了配合CPU读计数器当前值而设置的。 在读计数器时必须先用锁存命令将当前计数值在输出锁 存器中锁定,才可由CPU输入。
特点: 2. GATE=0,禁止计数,GATE=1,允许计数。因此要做到软件触发, GATE必须保持为高。但GATE不影响输出。
特点: 3. 若在计数期间写入新的计数值,则按新的计数值重新开始计数。
(6) 方式5 —— 硬件触发选通
开始计数),OUT输出端变低。在整个计数过程中,OUT 都维持为低,直到计数 为 0 时,输出变为高,输出一个单脉冲。
特点: 1. 若设置的计数值为N,则输出的单脉冲宽度即为N个输入脉冲间隔。 2. 当计数到 0 后,可再次由外部触发启动,输出一个同样宽度的 单拍脉冲,而不用再次送计数值。