微机原理课程设计报告.docx
- 文档编号:10549189
- 上传时间:2023-02-21
- 格式:DOCX
- 页数:20
- 大小:258.76KB
微机原理课程设计报告.docx
《微机原理课程设计报告.docx》由会员分享,可在线阅读,更多相关《微机原理课程设计报告.docx(20页珍藏版)》请在冰豆网上搜索。
微机原理课程设计报告
一、课程实际目的及意义
通过本次课程设计要掌握此三种芯片使用的方法,灵活运用课本知识,加深所学的知识,对所学的相关芯片的原理、内部结构、使用方法等有更加深刻的了解,学会利用课本知识联系实际应用及编程。
同时并了解综合问题的程序设计掌握实时处理程序的编制和调试方法,掌握一般的设计步骤和流程,使我们以后搞设计时逻辑更加清晰。
二、开发环境及设备
①设计环境
PC机一台、windowsXP系统、实验箱、导线若干。
②设计所用设备
8254定时器:
用于产生秒脉冲,其输出信号可作为中断请示信号送IRQ2。
8255并口:
用做接口芯片,和小键盘相连。
8259中断控制器:
用于产生中断。
LED:
六个LED用于显示时:
分:
秒值。
小键盘:
用于控制设置。
三、设计思想与原理
1、设计思想
本系统设计的电子时钟以8088微处理器作为CPU,用8254做定时计数器产生时钟频率,8255做可编程并行接口显示时钟和键盘电路,8259做中断控制器产生中断。
在此系统中,8254的功能是定时,接入8254的CLK信号为周期性时钟信号。
8254采用计数器0,工作于方式2,使8254的OUT0端输出周期性的负脉冲信号。
即每隔20ms,8254的OUT0端就会输出一个负脉冲的信号,此信号接8259的IR2,当中断到50次数后,CPU即处理,使液晶显示器上的时间发生变化。
其中8259只需初始化ICW1,其功能是向8259表明IRx输入是电瓶触发方式还是上升沿触发方式,是单片8259还是多片8259。
8259接收到信号后,产生中断信号送CPU处理。
2、设计原理
利用实验台上提供的定时器8254和扩展板上提供的8259以及键盘和数码显示电路,设计一个电子时钟,由8254中断定时,小键盘控制电子时钟的启停及初始值的预置。
电子时钟的显示格式HH:
MM:
SS由左到右分别为时、分、秒,最大记时59:
59:
59超过这个时间时分秒位都清零从00:
00:
00重新开始。
基本工作原理:
每百分之一秒对百分之一秒寄存器的内容加一,并依次对秒、分、小时寄存器的内容加一,六个数码管动态显示时、分、秒的当前值。
1、内容
利用实验台上提供的定时器8254和扩展板上提供的8259以及键盘和数码显示电路,设计一个电子时钟,由8254中断定时,小键盘控制电子时钟的启停及初始值的预置。
电子时钟的显示格式HH:
MM:
SS由左到右分别为时、分、秒,最大记时59:
59:
59超过这个时间时分秒位都清零从00:
00:
00重新开始。
2、要求
本实验要求设计一个定时显示装置,用六个数码管显示时间,用小键盘控制计时,设置和显示时间。
系统一运行就从00点00分00秒开始计时,并在数码管上显示时、分、秒当前值,而且,可以用键盘设置当前时间。
基本工作原理:
每百分之一秒对百分之一秒寄存器的内容加一,并依次对秒、分、小时寄存器的内容加一;六个数码管动态显示时、分、秒的当前值。
C键:
置初值,显示00:
00:
00
G键:
显示动态变化(启动表);
D键:
显示静态不变(表停止);
E键:
终止程序,返回DOS;
P键:
设置时:
分:
秒的值
3、设计环境
PC机一台、windowsXP系统、实验箱,导线若干。
4、设计所用设备
8254定时器:
用于产生秒脉冲,其输出信号可作为中断请示信号送IRQ2。
8255并口:
用做接口芯片,和小键盘相连。
8259中断控制器:
用于产生中断。
LED:
六个LED用于显示时:
分:
秒值。
小键盘:
用于控制设置。
三、设计所用芯片结构
1、8259A芯片的内部结构及引脚
中断控制器8259A是Intel公司专为控制优先级中断而设计开发的芯片。
它将中断源优先排队、辨别中断源以及提供中断矢量的电路集中于一片中。
因此无需附加任何电路,只需对8259A编程,就可以管理8级中断,并选择优先模式和中断请求方式,即中断结构可以由用户编程来设定。
在MD微机系统中,8259芯片工作于单片方式。
8259引脚图如图3.3,各引脚功能如下。
D7~D0——八条双向数据线;
WR(低电平有效)——写输入信号;
RD(低电平有效)——读输入信号;
CS(低电平有效)——片选输入信号;
A0——地址信号;
INT——中断请求信号;
INTA(低电平有效)——中断响应信号;
CAS0~CAS2——级联信号,形成一条专用8259A总线,以便多片8259A的级联;
图3.18259A引脚图
SP/EN——从编程/允许级联。
在缓冲方式中,可用做输出信号以控制总线缓冲器的接收和发送。
在非缓冲方式中,作为输入信号用于表示主片还是从片;
IR0~IR7——外部中断请求输入线。
要求输入的中断请求信号是由低电平到高电平的上升沿(并保持高电平到CPU响应时为止)或者是高电平。
8259中断矢量地址与中断信号之间的关系如表3.1所示:
表3.18259A中断矢量表
中断序号
0
1
2
3
4
5
6
7
功能调用
08H
09H
0AH
0BH
0CH
0DH
0EH
0FH
矢量地址
20H
~
23H
24H
~
27H
28H
~
2BH
2CH
~
2FH
30H
~
33H
34H
~
37H
38H
~
3BH
3CH
~
3FH
说明
时钟
键盘
可用
可用
串行口
可用
可用
可用
2、8255芯片的内部结构及引脚
8255可编程外围接口芯片是Intel公司生产的通用并行I/O接口芯片,它具有A、B、C三个并行接口,用+5V单电源供电,能在以下三种工作方式下工作:
方式0—基本输入/输出方式
方式1—选通输入/输出方式
方式2—双向选通输入/输出方式
8255引脚图如图3.2示,各引脚功能如下。
D7~D0——与CPU侧连接的八条双向数据线;
WR(低电平有效)——写输入信号;
RD(低电平有效)——读输入信号;
CS(低电平有效)——片选输入信号;
A0、A1——片内寄存器选择输入信号;
PA7~PA0——A口外设双向数据线;
PB7~PB0——B口外设双向数据线;
PC7~PC0——C口外设双向数据线;
RESET——复位输入信号
2、8255端口地址
表3.28255端口地址表
信号线
寄存器
编址
IOY3
A口
60H
B口
61H
C口
62H
控制寄存器
63H
3、8254芯片的内部结构及引脚
8254可编程定时/计数器是Intel公司生产的通用外围芯片之一,有3个独立的十六位计数器,技术频率范围为0~2MHZ,它所有的技术方式和操作方式都通过编程控制。
8254的功能用途是:
(1)延时中断
(2)可编程频率发生器
(3)事件计数器
(4)二进倍频器
(5)实时时钟
(6)数字单稳
(7)复杂的电机控制器
8254有六种工作方式:
(1)方式0:
计数结束中断
(2)方式1:
可编程频率发生器
(3)方式2:
频率发生器
(4)方式3:
方波频率发生器
(5)方式4:
软件触发的选通信号
(6)方式5:
硬件触发的选通信号
8254引脚图如图3.3示,各引脚功能如下。
D7~D0——八条双向数据线;
WR(低电平有效)——写输入信号;
RD(低电平有效)——读输入信号;
CS(低电平有效)——片选输入信号;
A0、A1——片内寄存器地址输入信号;
CLK——计数输入,用于输入定时基准脉冲或计数脉冲;
OUT——输出信号,以相应的电平指示计数的完成,或输出脉冲波形;
GATE——选通输入(门控输入),用于启动或禁止计数器的操作,以使计数器和计测对象同步。
表3.38254端口地址表
2、8254端口地址
信号线
寄存器
编址
IOY2
0#计数器
40H
1#计数器
41H
2#计数器
42H
控制寄存器
43H
四、具体模块设计
1、概述
本系统设计的电子钟以8088微处理器作为CPU,用8254做定时计数器产生时钟频率,8255做可编程并行接口显示时钟和键盘电路,8259做中断控制器产生中断。
在此系统中,8254的功能是定时,接入8254的CLK信号为周期性时钟信号。
8254采用计数器0,工作于方式2,使8254的OUT0端输出周期性的负脉冲信号。
即每隔20ms,8254的OUT0端就会输出一个负脉冲的信号,此信号接8259的IR2,当中断到50次数后,CPU即处理,使液晶显示器上的时间发生变化。
程序由以下模块组成:
系统共有5个功能模块,分别为,主控模块,显示模块,定时模块,中断模块,小键盘模块。
系统框图如下:
图一系统框图
2、主程序模块
主控模块是系的核心模块,对8254、8255A进行初始化,设置中断向量,扫描键盘根据按键值作相应的处理。
主要由软件实现。
它的主要功能是调用其它模块对系统工作进行协调,它的主要功能是读小键盘输入键值并执行要做的工作,如果键值为C则将显示初始值00:
00:
00置入显示缓冲,并调用显示模块显示。
如果键值为G则开中断,(中断程序为秒最低位加一)。
如果键值为D则关中断,停止动态显示。
如健值为P则连续六次调用小键盘模块,将键值依次存入显示缓冲。
并调用显示模块显示。
如果健值为E,则终止程序,返回DOS。
3、小键盘模块
小键盘模块送入主控模块的子功能模块。
由软件和硬件实现,硬件上由小键盘和8255互连,将小键值由8255送入主控模块。
软件上使用行扫描法获得键值并送回主控模块。
本课题只考虑去抖动。
执行一个约10ms的延时程序后再扫描键盘,若F0=1表示真正有键按下,从而消除了抖动影响。
实现代码如下:
keyrocnear
pushcx
kst:
moval,82h
movdx,p55ctl
outdx,al
moval,00h
movdx,pa55
outdx,al
movdx,pb55
inal,dx
oral,0f8h
cmpal,0ffh
jzdelay
movcx,0300h
dly:
loopdly
movcl,08h
movah,0feh
scan1:
movdx,pa55
moval,ah
outdx,al
movdx,pb55
inal,dx
oral,0f8h
cmpal,0ffh
jnzkeyn
rolah,1
deccl
jnzscan1
jmpkst
keyn:
pushax
movdx,pb55
relea:
inal,dx
oral,0f8h
cmpal,0ffh
jnzrelea
popax
notax
movsi,offsettable
movdi,offsetchar
movcx,24
tt:
cmpax,[si]
jznn
deccx
jzkst
addsi,02
incdi
jmptt
nn:
movdl,[di]
mov[char1],dl
movah,02h
int21h
popcx
jmpyang
delay:
calldisply
jmpkst
yang:
ret
keyendp
4、显示模块
显示模块是将显示缓冲区的数值送到LED显示的功能模块,显示缓冲区是由六个字节构成,分别保存小时的高位和低位,分钟的高位和低位,秒钟的高位和低位。
硬件上由六个LED构成,软件上由扫描显示的方法实现。
实现代码如下:
delay1:
decbx
jnzdelay1
cmpcl,20h
jzdisup2
incdi
shlcl,1
jmpdisup1
disup2:
popcx
ret
displayendp
displayprocnear
movcx,77ffh
led52:
calldisup
loopled52
disup:
pushcx
movdi,offsetmin1
movcl,01
disup1:
moval,0
movdx,portbit
outdx,al
moval,[di]
movbx,offsetled
xlat
movdx,portseg
outdx,al
moval,cl
movdx,portbit
outdx,al
movbx,35h
5、定时模块
定时模块是为8259提供中断请求信号的。
由一片8254实现,选用定时器0#,工作在方式3,由4时钟应该1秒走动一次,所以输出值应为1S,其输出信号可作为8259的中断请求信号。
6、中断处理模块
中断模块实现动态显示的,硬件为一片8259,由于中断请求信号为每秒一次,中断程序该为时间按秒增加,并显示,只要开中断,便可实现每秒显示时间增加一秒,从而达到动态显示的效果。
7、按如下接线图连接好试验箱上的芯片引脚,主要用到器件有8255,8254,LED,8259,小键盘。
8254的片选接地址208-20F,OUT1,OUT0接灯(测试用),GATE0,GATE1接+5V,CLK1接8259的IRQ2,CLK0接Q12(12分频)。
8255的片选接地址218-21F,实验箱已将其和小键盘相连。
LED的片选接地址210-217。
图二试验接线图
五、程序流程图
主程序流程图:
键盘扫描程序流程图:
(KEY)
中断处理程序流程图:
六、心得体会
附录一:
参考书目
1、戴梅萼,史嘉权编著.微型计算机技术及应用(第三版).北京:
清华大学出版社,2003
2、周明德编著.微型计算机系统原理及应用(第四版).北京:
清华大学出版社,2002
3、李顺增,吴国东,赵河明等.微机原理及接口技术.北京:
机械工业出版社,2006
4、杨立新.微型计算机原理和应用[M].北京:
科学技术文献出版社,1986.11
5、李大友.微型计算机原理[M].北京:
清华大学出版社,1998.7
6、眭碧霞.微型计算机原理与组成[M].人民邮电出版社,2003.8
附录二:
部分源代码
*********用两个74LS373进行数码管的动态显示;一个做段(要显示的笔画)选,一个做位选
PORTSEQU211H;数码管显示地址(选管)
PORTBEQU210H;数码管显示内容控制
;*********在8253的定时中断中,通过8255的8个PA口,3个PB口进行扫描
PAEQU220H;8255CS选择信号端
TC0EQU230H;8253CS选择信号端
;*********数据段
DATASEGMENT
COUNT1DB12;扫描键盘中断口标志CM读数码管
COUNT2DB13;延世13次中断标志
KREPDB0;防止连击标志,krep=0:
无键按下
KSHAKEDB0;键盘防抖
KFLAGDB0;功能键标志位kflag=1,2,3--key(A\B\C)pressed,4--key(F)pressed
SYMBLDB0;显示标志位0--displaybufer,1--displaytemp
FIRSTDB0;修改标志位check2digit0--hight,1--low
ENTERDB0;在缓冲区里有新的数字?
有则为1
TABLDW57FH,5BFH,5DFH,5EFH,5FEH,5FDH,5FBH,5F7H
DW67FH,6BFH,6DFH,6EFH,6FEH,6FDH,6FBH,6F7H
DW37FH,3BFH,3DFH,3EFH,3FEH,3FDH,3FBH,3F7H;键盘扫描码
ASCIDB"0123456789ABCDEFGMPRWXYS";键盘顺序码
MASEGDB"THEKEY_PREESEDISERROR!
",13,10,'$';按键出错提示字符串
NUMERRDB13,10,"THEENTEREDDIGITISERROR,INPUTAGAIN!
",13,10,'$'
;无效时间提示字符串
LED8DB3FH,06H,5BH,4FH,66H,6DH,7DH,07H,7FH,67H
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微机 原理 课程设计 报告