第4章节__定时器计数器接口电路.ppt

  1. 1、本文档共87页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第4章节__定时器计数器接口电路

BEEP PROC MOV AL, ;计数器2,方式3,16位计数,二进制计数 OUT 43H, AL ;写入控制字 MOV AX, 0533H ;计数初值为0533H=1331(1.193 18 MHz/1331=896 Hz) OUT 42H, AL ;写入计数初值低8位 MOV AL, AH OUT 42H, AL ;写入计数初值高8位 IN AL, 61H ;读8255端口B的原值 MOV AH, AL ;暂存AH OR AL, 03H ;使PB0=1、PB1=1 OUT 61H, AL ;输出,使扬声器发声 SUB CX, CX LOP: LOOP LOP ;延时 DEC BL ;BL值由入口参数提供,决定发声长短 JNZ LOP ;BL=6发长声,BL=1发短声 MOV AL, AH OUT 61H, AL ;恢复8255端口B的原值,停止发声 RET ;返回 BEEP ENDP 4.3 ICH5中的定时器/计数器功能 4.3.1 Intel 8254定时器/计数器 为了讨论ICH5中的定时器/计数器功能,需要先研究一下通用可编程定时器/计数器接口芯片Intel 8254。Intel 8254定时器/计数器与8253兼容,它包括了8253的所有功能,且性能比8253有所提升,它的操作方式以及引脚与8253完全相同。Intel 8254定时器/计数器性能的提升主要包括: (1) ?8254的计数频率更高,最高可达10 MHz(8254-2)。 (2) ?8254增加了一条读回命令(Read Back Command),读回命令可以把三个定时器/计数器通道的工作状态和当前计数值予以锁存。然后,可由CPU读取计数器通道的工作状态(8253不能),并可由CPU读取计数器的当前计数值(8254比8253多了一种读取当前计数值的方法)。 对工作状态和当前计数值予以锁存的读回命令的格式如图4-17所示。读回命令要写入8254的控制字寄存器。一条8254读回命令最多允许锁存全部三个计数器通道的工作状态和当前计数值,也可以仅锁存其中的一个或两个计数器通道的工作状态和当前计数值。 图4-17 8254的读回命令字 读回命令的各位作用如下: D5=0:锁存所选择的计数器的计数值; D4=0:锁存所选择的计数器的工作状态; D3=1:选择计数器2; D2=1:选择计数器1; D1=1:选择计数器0; D0:必须为0。 读回命令对某个计数器通道进行状态锁存之后,CPU就可以从该计数器端口读取一个工作状态字。8254的计数器状态字如图4-18所示。状态字各位含义如下: 图4-18 8254的计数器状态字 D7=1:表明该计数器OUT端输出为高电平,否则为低电平; D6=0:锁存的计数值有效,否则为空计数值,无效; D5~D0:8254初始化编程时设定的计数器方式。 CPU从计数器端口读取一个状态字后,下一步CPU就可以再读取一个或两个字节的锁存的当前计数值。具体应当读一个还是两个字节的当前计数值,取决于8254初始化编程时读写格式的设定。 4.3.2 ICH5中的8254定时器/计数器 ICH5中集成了8254定时器/计数器的功能。8254单元的时钟为14.318 18 MHz,其中三个定时器/计数器和控制字寄存器的端口地址与80x86系统的定时器/计数器相同,分别为 计数器0的端口地址:40H; 计数器1的端口地址:41H; 计数器2的端口地址:42H; 控制字寄存器的端口地址:43H。 ICH5中集成的8254定时器/计数器与80x86系统中的定时器/计数器的功能基本相同。计数器0工作于方式3,每个计数周期

文档评论(0)

ctuorn0371 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档