微机原理与接口技术——8254定时器/计时器

本文详细介绍了8254定时器/计数器的基本结构,包括控制寄存器、16位计数器和不同工作方式。重点讲解了分频器和方波发生器方式,并提供了PC应用示例及初始化编程实例,包括BCD码和二进制计数方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、 掌握8254定时器/计数器的基本结构

在这里插入图片描述

1、控制寄存器

初始化编程时,由CPU写入控制字,以决定计数器的工作方式,设置读出命令。此寄存器只能写入不能读出

2、计数器(16位)

8254有3个独立的计数器,每个计数器结构完全相同。
每个计数器对外有3个引脚:

  • GATE为门控信号输入端
  • CLK为计数脉冲输入端
  • OUT为输出信号信号端
    在这里插入图片描述

3、8254端口地址

A1A0=00,选中0#计数器;
A1A0=01,选中1#计数器;
A1A0=10,选中2#计数器;
A1A0=11,选中控制寄存器;

在这里插入图片描述

二、8254的工作方式

掌握具有初值自动给重装功能的方式2、方式3,包括计数过程、波形、周期和启动方式

方式2——分频器

  1. 计数过程:若GATE为高电平,程序员写入新的计数初值,不会影响正在进行的减一技术过程,只有计数器减到1之后,计数器才装入新的计数初值,并且按照新的计数初值开始计数。
  2. 波形:比例 1:N-1
    在这里插入图片描述
  3. 启动方式:软件启动

方式3——方波发生器

  1. 计数过程:当计数初值为偶数时,每来一个CLK脉冲,计数值减2,当计数值减到0时输出端改变极性,内部完成初值自动填装,继续计数。

  2. 波形比例为:N/2:N/2 即为(1:1)
    在这里插入图片描述

  3. 启动方式:软件启动

工作方式比较

在这里插入图片描述

三、例题

在这里插入图片描述
答案:8ms,8ms

四、8254在PC机上应用

在这里插入图片描述

五、8254初始化编程

在这里插入图片描述

例子

在这里插入图片描述
这里没有指明是按照BCD,还是二进制,一般化会指明。

BCD码计数

MOV AL,1010 0111H
OUT 43H,AL
MOV AL,40H
OUT 42H,AL

因为这是BCD码计数,所有初值为2000H(直接加在后面H即可),在D5D4位时,我采用10,即为只写高八位,低八位置零。

二进制计数

MOV AL,1011 0110H
OUT 43H,AL
MOV AX,2000
OUT 42H,AL
MOV AL,AH
OUT 42H,AL
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

silence_sz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值