微机原理与接口技术——8254定时器/计时器
2023-12-25 19:01:25
文章目录
一、 掌握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——分频器
- 计数过程:若GATE为高电平,程序员写入新的计数初值,不会影响正在进行的减一技术过程,只有计数器减到1之后,计数器才装入新的计数初值,并且按照新的计数初值开始计数。
- 波形:比例 1:N-1
- 启动方式:软件启动
方式3——方波发生器
-
计数过程:当计数初值为偶数时,每来一个CLK脉冲,计数值减2,当计数值减到0时输出端改变极性,内部完成初值自动填装,继续计数。
-
波形比例为:N/2:N/2 即为(1:1)
-
启动方式:软件启动
工作方式比较
三、例题
答案: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 AL,25H
OUT 42H,AL
MOV AL,01H
OUT 42H,AL
文章来源:https://blog.csdn.net/qq_64131064/article/details/135199702
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!