微型计算机系统原理及应用 第9章 第二十次课.ppt

微型计算机系统原理及应用 第9章 第二十次课.ppt

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

1. 数据总线缓冲器 这是8253与CPU数据总线连接的8位双向三态缓冲器。CPU用输入输出指令对8253进行读写的所有信息,都是通过这8条总线传送的。包括: (1) CPU在初始化编程时,写入8253的控制字; (2) CPU向某一通道写入的计数值; (3) CPU从某一个通道读取的计数值。 2. 读/写逻辑 这是8253内部操作的控制部分。首先有选片信号CS的控制部分,当CS为高电平(无效)时,数据总线缓冲器处在三态,与系统的数据总线脱开,故不能进行编程,也不能进行读写操作。其次,由这部分选择读写操作的端口(三个计数器及控制字寄存器),也由这部分控制数据传送的方向,读——数据由8253传向CPU,写——数据由CPU传向8253。 3. 控制字寄存器 在8253的初始化编程时,由CPU写入控制字以决定通道的工作方式。此寄存器只能写入而不能读出。 4. 计数器0,计数器1,计数器2 这是三个计数器/定时器通道,每一个都是由一个16位的可预置值的减法计数器构成。这三个通道的操作是完全独立的。 每个通道都是对输入脉冲CLK按二进制或二—十进制,从预置值开始减1计数。当预置值减到零时,从OUT输出端输出一信号。 计数器/定时器电路的本质是一个计数器。若计数器对频率精确的时钟脉冲计数,则计数器就可作为定时器。计数频率取决于输入脉冲的频率。在计数过程中,计数器受到门控信号GATE的控制。计数器的输入与输出以及与门控信号之间的关系,取决于工作方式。 计数器的初值必须在开始计数之前,由CPU用输出指令预置。在计数过程中,CPU随时可用输入指令读取任一计数器的当前计数值,这一操作对计数没有影响。 需要由D7D6这两位来决定是哪一个通道的控制字。因此,对三个通道的编程需要向同一个地址(控制字寄存器地址)写入三个控制字,它们的D7D6位分别指定不同的通道。在控制字中的通道选择与通道计数器的地址是两回事,不能混淆。计数通道的地址是用作CPU向计数器写初值,或者从计数器读取当前的计数值。 若要使计数器0工作在方式1,按BCD计数,计数值为30H。则初始化程序为: MOV AL,23H;设方式控制字 OUT 43H,AL;输出至控制字寄存器 MOV AL,30H;设计数值 OUT 40H,AL;输出至计数器0的高8位 注意: 虽然计数值是16位的,但在控制字中规定为只写高8位,故低8位自动设置为0。 若要使计数器2工作在方式2,按二进制计数,计数值为02F0H。则初始化程序为: MOV AL,084H;写入控制字 OUT 07H,AL MOV AL,0F0H OUT 06H,AL;写计数值的低8位 MOV AL,02H OUT 06H,AL;写计数值的高8位 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 济南大学控自动化学院 * 特点: 3. 若在计数期间写入新的计数值,则按新的计数值重新开始计数。 特点: 2. GATE=0,禁止计数,GATE=1,允许计数。因此要做到软件触发, GATE必须保持为高。但GATE不影响输出。 济南大学控自动化学院 * 例:计数器0工作模式4,初始化计数器,使装入计数器10 ?s后产生选 通信号(设时钟频率2MHz,8253端口地址为50H~53H)。 解:n+1=T/ TCLK=10/0.5=20 n=19=13H MOV AL, 18H OUT 53H, AL MOV AL, 13H OUT 50H, AL 0 0 0 1 1 0 0 0 通道0 只写低8位 方式4 二进制计数 济南大学控自动化学院 * (6) 方式5 —— 硬件触发选通—— 了解 在这种方式下,当写入控制字后,输出为高,当写入计数值后,计数器并不立即开始计数,而是由门控信号的上升沿触发启动。计数到 0 后,输出变低,经过一个CLK周期,输出又变高,计数器停止计数。等到下一次门控信号的触发才能开始新的计数。 特点: 1. CPU写入计数值的下一个CLK脉冲,将计数值装入计数器,再下一个 CLK脉冲开始计数,即在装入计数值后的第 N+1 个脉冲,才输出一个 负脉冲。 济南大学控自动化学院 * 特点: 2.

文档评论(0)

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

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

1亿VIP精品文档

相关文档