微机接口课程设计报告及源程序_第1页
微机接口课程设计报告及源程序_第2页
微机接口课程设计报告及源程序_第3页
微机接口课程设计报告及源程序_第4页
微机接口课程设计报告及源程序_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、目 录第1章 需求分析11.1 课程设计题目11.2 课程设计任务及要求11.2.1 课程设计任务11.2.2 课程设计要求11.3 软硬件运行环境及开发工具11.3.1 软硬件运行环境11.3.2 开发工具1第2章 概要设计22.1 设计原理及实现方法22.1.1 计数脉冲的产生和检测原理22.1.2 计数led显示原理22.1.3 扬声器的驱动原理32.2 主要芯片说明32.2.1 8255管脚与功能32.3 设计原理图5第3章 详细设计73.1 硬件设计与实现73.1.1 设计接线图73.2 程序流程图73.2.1 系统流程图73.2.2 模块流程图83.3 功能模块实现93.3.1 慢

2、速脉冲产生程序93.3.2 开关切换功能程序103.3.3 脉冲检测及计数程序103.3.4 计数显示程序113.3.5 扬声器驱动程序12第4章 系统调试与操作说明134.1 系统调试134.2 操作说明13第5章 课程设计总结与体会14参考文献15附录 源程序16第1章 需求分析1.1 课程设计题目慢速计数系统的设计1.2 课程设计任务及要求1.2.1 课程设计任务1设计一个慢速技术系统,。28255一个端口输出慢速脉冲(周期约0.5秒)给另一端口计数,端口检测脉冲后进行计数。31个开关控制切换计数/暂停;用另一个开关实现计数清零功能输入。4用2位7段led数码管显示当前计数值(采用十进制

3、计数)。5每计数10次,扬声器鸣叫约1秒。1.2.2 课程设计要求完成实验方案论证,进行慢速计数系统电路硬件设计,画出电路原理图及实验电路图;搭建实验电路,进行软件编程、调试、运行以及使用说明文档的建立等一整套工作任务。进行慢速计数系统控制程序设计(采用汇编语言);系统联调,提交一个符合上述功能要求的慢速计数系统的设计。1.3 软硬件运行环境及开发工具1.3.1 软硬件运行环境利用tdn86/88实验平台进行硬件连接,利用tdn集成开发环境进行慢速计数系统的程序设计(采用汇编语言),调试,直到满足设计要求。1.3.2 开发工具实验所使用的实验开发设备是tdn86/88型多功能微机实验平台,它的

4、硬件由基本系统、外设功能模块和面包板实验区三大部分,按模块化开放式结构设计而成。第2章 概要设计2.1 设计原理及实现方法本课程设计的慢速计数系统已8086微处理器为cpu,主要用8255a来实现计数和显示。用8255a的下c口的一个端口产生计数脉冲,并用8255a下c口的一个端口检测计数脉冲,并通过8086cpu计数,计数的同时,通过8255a的a口和b口分别驱动两个七段码led显示个位数字和十位数字,计数每到10,触发8255a的下c口产生脉冲驱动扬声器发声。2.1.1 计数脉冲的产生和检测原理在本慢速计数系统中,计数脉冲可以用方波实现,而电平的高低变化可以通过8255a的c口的置数命令分

5、别对产生计数脉冲的端口置1后延时并置0代替。表 2.1 8255a c口置数命令控制字d7d6d5d4d3d2d1d0特征位0 不 用(写0)位 选 择000=c口0位001=c口1位111=c口7位1=置位(高电平)0=复位(低电平)2.1.2 计数led显示原理在计数时,需要实时显示当时的计数值并能显示出来,这就需要用到七段码led,而七段码led不能直接显示十进制数字,故需要通过查表找到每个数字对应的编码并通过led显示出来。led数码管也称半导体数码管,是目前数字电路中最常用的显示器件。它是以发光二极管作笔段并按共阴极方式或共阳极方式连接后封装而成的。图5所示是两种led数码管的外形与

6、内部结构,、分别表示公共阳极和公共阴极,ag 是7个电极,dp为小数点。 图 2.1 led内部结构及连线2.1.3 扬声器的驱动原理本次课程设计要求计数到10时蜂鸣1秒,而实验系统用到的扬声器,有两个管脚,在驱动扬声器发声时,只需要将其一只管脚接地,另外一只管脚接入方波脉冲就会开始蜂鸣,在蜂鸣一秒后,再将其管脚接入低电平即可停止蜂鸣。故可参照计数脉冲的实现原理,在计数到10后,可通过c口的置数命令将c口的一端口产生高电平,并通过延时程序产生延时,在延时完成后,又通过c口的置数命令将c口产生低电平停止蜂鸣。2.2 主要芯片说明2.2.1 8255管脚与功能 图2.2 8255的引脚图引脚功能:

7、reset:复位输入线,当该输入端处于高电平时,所有内部寄存器(包括控制寄存器)均被清除,所有i/o口均被置成输入方式。 cs:芯片选择信号线,当这个输入引脚为低电平时,即/cs=0时,表示芯片被选中,允许8255与cpu进行通讯;/cs=1时,8255无法与cpu做数据传输。 rd:读信号线,当这个输入引脚为低电平时,即/rd=0且/cs=0时,允许8255通过数据总线向cpu发送数据或状态信息,即cpu从8255读取信息或数据。 wr:写入信号,当这个输入引脚为低电平时,即/wr=0且/cs=0时,允许cpu将数据或控制字写入8255。 d0d7:三态双向数据总线,8255与cpu数据传送

8、的通道,当cpu 执行输入输出指令时,通过它实现8位数据的读/写操作,控制字和状态信息也通过数据总线传送。 pa0pa7:端口a输入输出线,一个8位的数据输出锁存器/缓冲器, 一个8位的数据输入锁存器。 pb0pb7:端口b输入输出线,一个8位的i/o锁存器, 一个8位的输入输出缓冲器。 pc0pc7:端口c输入输出线,一个8位的数据输出锁存器/缓冲器, 一个8位的数据输入缓冲器。端口c可以通过工作方式设定而分成2个4位的端口, 每个4位的端口包含一个4位的锁存器,分别与端口a和端口b配合使用,可作为控制信号输出或状态信号输入端口。 a1,a0:地址选择线,用来选择8255的pa口,pb口,p

9、c口和控制寄存器. 当a1=0,a0=0时,pa口被选择; 当a1=0,a0=1时,pb口被选择; 当a1=1,a0=0时,pc口被选择; 当a1=1.a0=1时,控制寄存器被选择。表 2.2 8255端口地址端口地址pa口60hpb口61hpc口62h控制口63h2.3 设计原理图 图 2.3 设计原理图原理图中8255a d0d7端接系统总线。图中七段码显示器管脚排列如下: 图 2.4 led引脚图原理图中的8255引脚与七段码led接线如下: pa0 pa1 pa2 pa3 pa4 pa5 pa6 pa7 abcdefgdp图2.5 8255与七段码连线图第3章 详细设计3.1 硬件设计

10、与实现3.1.1 设计接线图 pc7 pa0pc6 pa1pc5 pa2pc4 pa3pc3 pa4pc2 pa5pc1 pa6pc0 pa7 pb0 pb1 pb2 pb3 pb4 pb5 pb6 pb7abcdefgdpabcdefgdp k7 k6switch unitd0d1d2d3d4d5d6d78086系统总线图 3.1 设计接线图图3.2 程序流程图3.2.1 系统流程图开始8255初始化,寄存器清零调用脉冲产生模块,产生脉冲产生计数脉冲调用开关状态检测模块检测开关状态调用脉冲检测模块检测计数脉冲调用计数显示模块显示计数值调用扬声器驱动模块驱动扬声器蜂鸣结束图 3.2 系统流程图

11、3.2.2 模块流程图图 3.4 脉冲计数模块开始c口置1out 63h,00000001b延时程序c口置0out 63h,00000000b开始计数器清零读取pc7状态pc7=1读取pc6状态pc6=0继续计数y图3.3 脉冲产生模块流程图开始mov al,00000001bout 62h,alc口置1,产生高电平延时程序mov al,00000000bout 62h,alc口置0,产生低电平结束开始inc dl个位大于10?十位加一个位清零查表得到个位段码out 60h,al十位大于10?十位清零查断码表得到十位数段码out 61h,al图 3.5 计数显示模块流程图图 3.6 扬声器驱动

12、模块流程图3.3 功能模块实现3.3.1 慢速脉冲产生程序本课程设计中,慢速脉冲产生原理是:通过8255a的c口的置数命令,分别对脉冲口作置1置0命令,这样就产生了010的脉冲信号,从而推动计数器计数。本课程设计是pc2输出产生脉冲。该模块具体程序如下:output: mov al,00000100b ;置pc2=0 out 62h,al ;由c口输出 pop ax ;出栈,恢复ax push ax mov al,00000101b ;置pc2=1 out 62h,al pop ax3.3.2 开关切换功能程序本课程设计的功能开关有两个k7和k6,分别连接c口的pc7和pc6。k7的功能是暂停

13、,当k7开关置1时计数暂停,置0继续;k6的功能是清0,当k6开关置1时计数清0,置0后重新开始计数。该模块具体程序如下:zero: mov dl,00h ;个位清零 mov dh,00h ;十位清零 stop: in al,62h ;pc7控制暂停,为1暂停 test al,80h ;用test只测试比较而不将结果保存 jnz stop ;如果不为0则跳转到stop in al,62h ;pc6清零开关,为1清零 test al,40h jnz zero ;如果不为0则跳转到zero3.3.3 脉冲检测及计数程序本课程设计中pc2是用于输出产生脉冲,pc5是用于检测输入的脉冲。只有当pc5检

14、测到pc2为高电平时才开始执行计数程序。计数原理:首先检测脉冲信号,如果检测到脉冲信号,个位加1,然后判断个位是否达到10,如果不为10,则将个位数字显示在数码管1上;如果为10则将十位加1,个位清零,然后显示在数码管上。判断完个位后再判断十位,如果十位不为10则将十位数字显示在数码管上;如果为10则将十位清零。具体代码如下:timmer: mov cl,0ah ;装入计数初值 l1: call dellay ;调用延时程序 in al,62h ;pc5脉冲检测 test al,20h jnz l3 ;pc2位为1则跳转到l3,否则跳到timmer jmp timmerl3: inc dl ;

15、个位加一 cmp dl,0ah ;判断是否大于10 jnz disp ;不为10则跳到disp(显示程序) inc dh ;个位大于10向十位进位 mov dl,00h ;个位清零 cmp dh,0ah ;比较十位是否为10 jnz a0 ;不为10则跳到a0 mov dh,00h ;为10则清零 dellay proc ;延时子程序 push cx mov cx,0f000h ;送入计数初值a3: push ax pop ax loop a3 ;循环执行压栈出栈,直到cx为0 pop cx ret dellay endp3.3.4 计数显示程序计数显示功能的实现主要是实现获取个位和十位数字后

16、,通过换码指令,得到各位数字对应的七段码,然后将对应的七段码送到相应的七段码led驱动口,就可以将个位数字和十位数字在七段码显示器上显示出来。data segment ;数据段定义tab1 db 3fh,06h,5bh,4fh,66h,6dh,7dh,07h,7fh,6fh ;七段码data endsdisp: mov al,dl ;显示个位数 mov bx,offset tab1 ;取段码表首地址 xlat ;查表得段码 out 60h,al ;a口输出个位并显示a0: mov al,dh ;显示十位数 mov bx,offset tab1 ;取段码表首地址 xlat ;查表得段码 out

17、61h,al ;b口输出十位3.3.5 扬声器驱动程序本课程设计的接线图中是pc0控制喇叭发声的。当pc0=1时喇叭发声,当pc0=0时喇叭不发声。而要求计数达到10、20、30.90时发声,那么驱动喇叭发声的条件就是计数初值为10的cl减到0时喇叭发声。具体程序如下: ring proc ;蜂鸣子程序 mov al,00000001b ;pc0控制喇叭发声 out 62h,al push cx mov cx,5000hl2: loop l2 ;以上两句为喇叭发声的延时 mov al,00000000b ;喇叭停止发声 out 62h,al pop cx ret ring endp第4章 系统

18、调试与操作说明4.1 系统调试先依照设计要求编写程序,在软件上进行编译并对程序进行调试直至通过编译,若顺利通过编译则可以按设计要求连接硬件电路,检查连接无误后,将程序编译、连接后加载到芯片中进行实际仿真,若出错则检查修改程序功能错误和硬件连接错误,直至仿真效果与设计要求一致。 4.2 操作说明 将程序编译,连接,加载后,运行开始仿真,按照设计要求,在运行后会进入计数状态,两个七段码显示器会实时显示计数值,将开关k7拨到”1”状态,计数暂停,七段码显示器显示暂停前的计数值;将开关k6拨到”1”状态,计数清零;计数每到10后,扬声器蜂鸣。第5章 课程设计总结与体会通过这次的课程设计,我回顾了许多之

19、前学习过的微机原理知识,又一次了解了相当多的汇编语言规则和知识,进一步了解了8255a各引脚的功能, 8255a和系统总线之间的连接, 8255a和cpu之间的数据交换,以及8255a的内部逻辑结构。我深入掌握了8255a显示电路的基本功能及编程方法,同时我深入了解了8255等芯片的工作方式、作用。通过这次课程设计,我最大的收获就是培养了自己的动手能力和独立解决问题的能力,也充分体会到了自己设计东西的乐趣、也意识到了自己查阅资料和团队沟通合作的重要性,也明白了在学习中光只是学习理论是不够的,必须亲自去试着实践,将理论应用到实践中,亲自去经历才能对它们真正的掌握。当我完成这个设计时,发现脑中关于

20、微机原理的知识更加清晰系统了。这让我相信,只有在不断的尝试,不断的动手去操作后,所学的理论知识才能真正地转化成自己的东西。我想我以后不管在什么方面,特别是在研究设计方面,都会有不错的成绩。动手加动脑才是成功的关键,一味的在理论上追根问底在现实中很难实现。这是我从这次课程设计中得到的最大的体会。通过这次课程设计,我最大的收获就是自己的动手能力和独立解决问题的能力得到了很大的提高,也充分体会到了自己设计东西的乐趣、学会查阅资料和对别人的东西融会变通的重要性,也明白了很多知识光靠趴在书本上学是学不到其中的精髓的,必须亲自去试着实践,亲自去经历才能对它们真正的掌握。 参考文献1 何超. 微型计算机原理

21、及应用.中国水利水电出版社,20072 杨立. 微型计算机原理与接口技术学习与实验指导. 中国水利水电出版社,2008.3 彭虎,周佩玲,傅忠谦.微机原理与接口技术(第二版).电子工业出版社,2008.4 朱承高.电工及电子技术手册m.北京:高等教育出版社,19905 姚燕南,薛均义.微型计算机原理.西安:西安电子科技大学出版社,20006 张迎新.单片微型计算机原理、应用及接口技术.北京:国防工业出版社,1999.设计者: 操时力 日 期: 2011年 6 月 16 日附录 源程序data segment tab1 db 3fh,06h,5bh,4fh,66h,6dh,7dh,07h,7fh

22、,6fhdata endsstack segment stackdw 64 dup(?)stack endscode segmentassume cs:codestart:mov ax,datamovds,axmoval,10001000b ; 8255方式字 out 63h,al zero: mov dl,00h ;清零 mov dh,00h timmer:mov cl,0ah l1:call dellayoutput: push ax mov al,00000100b out 62h,al pop ax stop: in al,62h ;pc7控制暂停,为1暂停 test al,80h j

23、nzstop in al,62h ;pc6清零开关,为1清零test al,40hjnz zeroin al,62h ;pc5脉冲检测test al,20hjnz l3jmp timmerl3:inc dl ; 个位加一cmp dl,0ah ;判断是否大于10jnz disp ;不小于10则显示inc dh ;个位大于10向十位进位mov dl,00h ;个位清零disp:mov al,dl ;显示个位数mov bx,offset tab1 ;取段码表首地址 xlat ;查表得段码 out 60h,al ;a口输出个位并显示 cmp dh,0ah jnz a0 mov dh,00h a0: mov al,dh mov

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论