实验十 可编程的计时、定时器 8253芯片.doc

实验十 可编程的计时、定时器 8253芯片.doc

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

实验十 8253 可编程计数器/定时器芯片 一、实验目的 1、掌握8253的主要性能及其初始化编程。 2、学会根据实验要求设计8253的接口电路。 二、实验技术准备 8253主要功能有: (1)一片上有三个独立的16位计数器通道。 (2)每个计数器都可以按照二进制或十进制计数。 (3)每个计数器的计数速率可达2MHz。 (4)每个通道有6种工作方式,可由程序设置和改变。 8253内部结构 8253管脚图 注:实验箱上使用的是8254芯片,8254芯片是8253芯片的增强型,管脚完全相同。 实验箱上的8254芯片电源和数据线均已连接好,实验时连接好读写控制模块信号 芯片即可工作。 8253的端口选择表 CS RD WR A1 A0 寄存器选择和操作 0 1 0 0 0 写入计数器#0 0 1 0 0 1 写入计数器#1 0 1 0 1 0 写入计数器#2 0 1 0 1 1 写入控制寄存器 0 0 1 0 0 读计数器#0 0 0 1 0 1 读计数器#1 0 0 1 1 0 读计数器#2 0 0 1 1 1 无操作(三态) 1 × × × × 禁止(三态) 0 1 1 × × 无操作(三态) 8253控制字格式 计数值N与输出波形关系 方式 N与输出波形的关系 0 写入计数值N后,经过N+1个CLK脉冲输出变高 1 单拍脉冲的宽度为N个CLK脉冲 2 每N个CLK脉冲,输出一个宽度为CLK周期的脉冲 3 写入N后,输出:1)1/2N个CLK高电平,1/2N个CLK低电平(N为偶数)2)(N+1)/个CLK高电平,(N-1)/2个CLK低电平(N为奇数) 4 写入N后过N+1个CLK,输出宽度为1个CLK脉冲 5 门控触发后,过N+1个CLK,输出宽度为1个CLK脉冲 门控输入信号的作用 方式 GATE 低或变为低 上升沿 高 0 禁止计数 允许计数 1 1)启动计数 2)下一个CLK脉冲使输出变低 2 1)立即计数 2)立即使输出变高 1)重新装入计数值 2)启动计数 允许计数 3 1)禁止计数 2)立即使输出变高 启动计数 允许计数 4 禁止计数 允许计数 5 启动计数 8253有六种不同的工作方式: 方式0——计数结束产生中断方式 方式1——可编程单次脉冲方式 方式2——分频工作方式 方式3——方波方式 方式4——软件触发选通方式 方式5——硬件触发选通方式 我们要求通过对方式0、方式1的实验,来了解和掌握8253主要性能及其初始化编程。 方式0 计数器结束中断方式 当选定8253工作于方式0,并对选定的计数器写入控制字时,该计数器的输出端OUT立即变为低电平。要使计数器能够进行计数,门控信号GATE必须为高。若CPU利用输出指令向计数器写入计数值时(N=5),写WRn的上升沿把计数值写入计数寄存器。在WRn上升沿后的下一个时钟脉冲CLK的下降沿时,才把计数值N写入计数寄存器执行单元CE。在CLK到来时开始减1计数。总共要经过N+1个CLK脉冲后计数器减为0,这时OUT引脚由低电平变为高电平。利用由低电平变为高电平正跳变信号向CPU发出中断请求。 方式0波形图 方式1 可编程单稳态输出方式 当CPU用控制字设定计数器工作于方式1时,计数器的输出OUT立即变为高电平,在CPU装入计数值N后,必须等到GATE由低电平到高电平的跳变,产生一个上升沿后,才能在下一个时钟脉冲CLK的下降沿将N值装入计数器执行单元,同时输出端OUT由高电平向低电平跳变,以后每来一个时钟脉冲,计数器就开始减1操作,当计数器的值减为0时,OUT产生由低到高的正跳变。 这样,在OUT的引脚得到一个负的单脉冲,单脉冲的宽度可以由程

文档评论(0)

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

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

1亿VIP精品文档

相关文档