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

文章目录

一、 掌握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码计数

bash 复制代码
MOV AL,1010 0111H
OUT 43H,AL
MOV AL,40H
OUT 42H,AL

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

二进制计数

bash 复制代码
MOV AL,1011 0110H
OUT 43H,AL
MOV AX,2000
OUT 42H,AL
MOV AL,AH
OUT 42H,AL
相关推荐
躺着要饭14 分钟前
AD20 Components没有了,空了
嵌入式硬件
一路往蓝-Anbo2 小时前
C语言从句柄到对象 (一) —— 全局变量的噩梦与“多实例”的救赎
c语言·开发语言·stm32·单片机·嵌入式硬件·物联网
松涛和鸣2 小时前
DAY42 SQLite3 : Dictionary Import and Data Query Implementation with C Language
linux·c语言·数据库·单片机·网络协议·sqlite
d111111111d3 小时前
STM32中USART和UART的区别是什么?
笔记·stm32·单片机·嵌入式硬件·学习
一路往蓝-Anbo3 小时前
C语言从句柄到对象 (三) —— 抛弃 Malloc:静态对象池与索引句柄的终极形态
c语言·开发语言·数据结构·stm32·单片机·算法
集芯微电科技有限公司3 小时前
PC1001超高频率(50HMZ)单通单低侧GaN FET驱动器支持正负相位配置
数据结构·人工智能·单片机·嵌入式硬件·神经网络·生成对抗网络·fpga开发
一路往蓝-Anbo4 小时前
C语言从句柄到对象 (二) —— 极致的封装:不透明指针与 SDK 级设计
c语言·开发语言·数据结构·stm32·单片机·嵌入式硬件
dlz08364 小时前
点亮LED灯
单片机·嵌入式硬件
上大科技蔡生4 小时前
AH6304X:60V/2A 多模式,升降压LED恒流DCDC驱动器
单片机·嵌入式硬件·led·dcdc
曜华激光5 小时前
光伏电池串性能测试仪检测精度极高
单片机·嵌入式硬件