微机原理课程设计报告

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

江苏大学京江学院

JIANGSU UNIVERSITY

微机原理课程设计

电子钟

学院名称:京江学院

专业班级:J计算机1401

学号:4141110020

学生姓名:潘庆

指导教师:杨旭东

2017 年 1 月

一、实验目的

•掌握综合使用基本输入输出设备、通用接口芯片、专用接口芯片的方法;•掌握实时处理程序的编制和调试方法;

•掌握8253、8259、8255的使用

•掌握小键盘、LED八段式发光二极管和蜂鸣器的使用

二、实验内容

•利用8253的定时功能,产生0.5S的定时中断;

•在F5区的数码管上显示时间格式为“时:分:秒”(24小时)

•允许通过键盘的按键设置时钟的初值;

•允许通过键盘的按键控制时钟的启停;

•分秒值为59分55秒时开始报时,每秒钟蜂鸣器鸣叫一声,到整点报时停止。

三、使用的芯片及占用端口地址

•8253芯片:主要用于产生定时中断,定时时间为0.5S

•端口地址:0260H~0263H

•8255芯片:主要用于控制键盘输入和LED数码管输出

•端口地址:0270H~0273H

•8259芯片:主要用于产生中断管理

•端口地址:0250H~0251H

四、硬件连接方案

•键盘的控制——由8255的B口控制;

•LED显示模块——由8255的B口和A口控制;

•时间的精确定时——用8254定时器0产生50ms的中断信号;

•整点报时控制——用8255的某一位信号控制8254的GATE1。GATE=1时,OUT1信号控制蜂鸣器鸣叫;GATE=0,蜂鸣器停止蜂鸣。

五、设计的系统连接总逻辑图

键盘与LED(F5)

A:按键的列线

B:数码管段码

C:数码管选择脚

D:按键的行线

蜂鸣器(F8)

Ctrl:控制接口,0-蜂鸣8253(C4)

CS:片选信号,低电平有效;A0、A1:地址信号;

8255(D3)

8259(B3)

六、程序模块划分及各模块程序流程图

•主程序模块:对8254、8259A等芯片进行初始化,设置中断向量,扫描键盘,根据按键值作相应的处理。流程图参见图

•注意:设置初始时间时要考虑边界,时间的最大值为23:59:59,不能超出此范围。

•8254中断服务程序:刷新一遍数码管,计时时间到一秒,修改当前时间,整点报时。流程图参见图

七、实验中遇到的问题,解决办法及实验心得体会

这次课程设计有一定的难度,期间遇到了种种困难,卡住了很久,比如在做显示的时候,先要全熄数码管,然后扫描按键,还要很好地控制延时去抖动,这是件挺繁琐的事,另外,按键之后需要给按键一个扫描码,接着转化成字形码,能够识别并在数码管上显示,也花了很多时间,再比如在设置时间的时候,对于延时时间的拿捏也很难,需要在buf缓冲区存放值,修改时,让修改位熄灭,其余位为0,若超出规定位数,则不修改,显示原值。老师在我完成规定任务后也设下了一个小挑战,将8255的一根接线调换了位置,要求仍正确显示,最后我想出的解决的方法是段位码改共阳极,键盘扫描里修改相应端口,开头输入部分修改8255初始化控制字即可。

这次课程设计对于这门课的认知的提升很有帮助,本来只是理解了理论,对于亲自动手实现还是感到茫然,甚至不相信自己能完成,但是在一步一步实现各个功能模块后,发现点连成了线,线动成面,知识点是能够串联起来的,只要自己愿意动手,愿意思考,没有什么是做不成的,当然期间必然会遇到各种各样的问题,只要肯向老师或同学请教,他们也一定会给你的思维一些启发。这次的课程设计虽然只是做了一个看似简单的电子钟,但是它几乎涵盖了我们这学期所学的大部分内容,完成这项课程设计必然要深入理解课本上的知识,这就起到了查漏补缺,融会贯通的作用,我想这对日后学习其他硬件方面的知识都是很有益的,也很大程度上激发了我对硬件方面课程的更大热情。

八、源程序清单

.MODEL TINY

C0_8253 EQU 260H ;计数器0的端口地址

C1_8253 EQU 261H ;计数器1的端口地址

C2_8253 EQU 262H ;计数器2的端口地址

CTRL_8253 EQU 263H ;控制端口的端口地址

PA_8255 EQU 270H ;端口A的地址

PB_8255 EQU 271H ;端口B的地址

PC_8255 EQU 272H ;端口C的地址

CTRL_8255 EQU 273H ;控制端口的端口地址

EVEN_8259 EQU 250H

ODD_8259 EQU 251H

.STACK 100

.DATA

BUFFER DB 0,0,0,0,0,0 ;数码上显示的内容

KEY DB 0

FLAG DB 1

BUF DB 0,?

SEG_TAB DB 03FH, 06H,05BH,04FH, 66H, 6DH, 7DH,07H,7FH,6FH;0~9的段码表SEG_TAB2 DB 0BFH, 86H,0DBH,0CFH, 0E6H, 0EDH, 0FDH,87H,0FFH,0EFH

.CODE

START: MOV AX,@DATA

MOV DS,AX

MOV ES,AX

NOP

MOV AL,30H ;00110000B,计数器0,方式0,二进制计数

MOV DX,CTRL_8253

OUT DX,AL

MOV DX,C0_8253

MOV AL,0DH

;Fout=1/25ms=40Hz,Fclk=31250Hz,N=Fclk/Fout=31250Hz/40Hz=781,N=781 OUT DX,AL

MOV AL,03H

相关文档
最新文档