可任意停止启动的电子时钟_第1页
可任意停止启动的电子时钟_第2页
可任意停止启动的电子时钟_第3页
可任意停止启动的电子时钟_第4页
可任意停止启动的电子时钟_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

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

文档简介

1、可任意停止启动的电子秒表目录一、课程设计要求2二、课程设计目的3三、设计思想3四、所用芯片及其工作原理介绍31.808632.825343.8255a44.8259a55.led5五、程序流程图6六、原理图8七、心得体会9八、致谢10九、参考文献11十、附录12一、 课程设计要求6位led数码显示,计时单位为1/100秒。利用功能键进行启/停控制。其功能为:上电后计时器清0,当第一次(或奇数次)按下启/停键时开始计数。第2次(或偶数次)按下该键时停止计时,再一次按启/停键时清零后重新开始计时。二、 课程设计目的 “微机原理与接口技术”是一门实践性很强的技术基础课程。微机原理及应用课程设计是一项

2、实践性很强的实训环节,运用所学的汇编语言及8086微处理芯片设计一个电子秒表,通过实现它的的一些基本功能,能够熟练运用汇编语言的一些基本指令,通过实践能够加深对汇编语言的理解和对8086微处理器、253可编程定时器、8259a可编程中断控制器、8255a可编程并行i/o接口芯片的基本功能的认识。在设计过程中,提高学生的实践编程能力和硬件设计能力,增加编程的信心。也可以进一步巩固和融会贯通所学的汇编语言,并且可以培养学生查找资料的能力和培养自己分析问题解决问题的能力,微机原理及应用课程设计的过程所体现的是一种工程设计的思维方法,要学会在生活实践中运用这种思维。三、 设计思想 电子秒表要实现的功能

3、:用按键中断来控制整个程序,按一下key1启动电子秒表,再按一下暂停,按一下key2键清零,用六个七段数码管显示时间。整个程序涉及到8255、8253和8259三个芯片。给8253的clk0提供一个频率为10khz的时钟信号, 8253的out0连接8259的irq7,8253的gate2连接正5伏电压,采用计数器0每隔0.01秒产生一次中断并且计数,写入以偏移地址4000h开始的6个内存单元,然后利用8255将内存单元的数据输出到七段数码管。由于按键中断优先于8259的7号中断,所以程序只有在按一下key1才启动电子秒表,再按一下暂停,按一下key2键清零,如果超出了60分,整个程序自动重新

4、开始。四、 所用芯片及其工作原理介绍1. 8086 8086cpu是16位微处理器,工作电源为单一5v,它的外部数据总线为16位,地址线为20根,故寻址的地址空间为1mb。8086具有一个功能相对完善的指令系统,能对各种类型的数据进行处理。它可以在两种不同的模式下工作,即最大工作模式和最小工作模式。所谓最小模式,就是微型计算机系统中只有8086或8088一个微处理器,在这个系统,所有的总线控制信号直接由cpu提供。最大模式就是微型计算机系统中包含有两个或多个微处理器,其中一个主处理器是8086或8088微处理器,其他处理器称为协处理器,它们协助主处理器工作。2. 8253可编程定时器/计数器。

5、有多种工作方式,此设计中选用方式2。首先用输出指令向控制寄存器写入一个控制字,用输出指令向选中的计数器端口地址写入一个计数初值,然后, 定时/计数器按控制字要求计数。计数从“计数初始值”开始,每当clk信号出现一次,计数值减1,当计数值减为0时,从out端输出一个低电平(具体形式与工作模式有关)。当clk信号出现时,计数值是否减1(即是否计数),受到“门控信号”gate的影响,一般,仅当gate有效时,才减1.门控信号gate如何影响计数操作,以及输出端out在各种情况下输出的信号形式与定时/计数器的工作模式有关。3. 8255a微机系统的信息交换有两种方式:并行通信接口方式和串行通信接口方式

6、。接口电路在cpu和i/o设备之间起着信号的变换和传输的作用。8255a可为86系列cpu与外部设备之间提供并行输入/输出的通道。由于它是可编程的,可以通过软件来设置芯片的工作方式,因此,用8255a连接外部设备时,通常不用再附加外部电路,使用教方便。 并行接口是在多根数据线上,以数据字节/字与i/o设备交换信息。在输入过程中,输入设备把数据送给接口,并且使状态线“输入准备好”有效。接口把数据存放在“输入缓冲寄存器”中,同时使“输入回答”线有效,作为对外设的响应。外设在收到这个回答信号后,就撤消数据和“输入准备好”信号。数据到达接口中后,接口会在“状态寄存器”中设置输入准备好标志,或者向cpu

7、发一个中断请求。cpu可用查询方式或中断方式从接口中读取数据。接口中的数据被读取后,接口会自动清除状态寄存器中的标志,且撤消对cpu的中断请求。在输出过程中,每当输出寄存器可以接收数据,接口就会将状态寄存器中“输出准备好”状态置1或向cpu发一个中断请求,cpu可用查询或中断方式向接口输出数据。当cpu输出的数据到达接口后,接口会清除“输出准备好”状态,把数据送往外设,并向外设发一个“数据输出准备好”信号。外设受到驱动后,便接收数据,并向接口电路发一个“输出回答”信号,接口收到该回答信号后,又将状态寄存器中“输出准备好”置位,以便cpu输出下一个数据。4. 8259a1. ir线上提出了中断请

8、求的中断源,即出现请求,irr中断请求寄存器(共有8位d7d0)对应于连接在ir0ir7线上的外设的中断请求,哪一根输入线有请求,哪一根输入线就置1。2. 若ocw1(imr中断屏蔽寄存器)未使该中断请求屏蔽(对应位为0时不屏蔽),该请求被送入pr(优先权分析器)比较。否则,不送入pr比较。3. pr把新进入的请求与isr(服务中寄存器)中正在被处理的中断进行比较。如果新进入的请求优先级较低,则8259不向cpu提出请求。如果新进入的请求优先级较高,则8259使int引脚输出高电平,向cpu提出请求。4. 如果cpu内部的标志寄存器中的if(中断允许标志)为0,cpu不响应该请求。若if=1,

9、cpu在执行完当前指令后,从cpu的inta引脚上向8259发出两个负脉冲。5.第一个 inta负脉冲到达8259时,8259完成以下三项工作:a.使irr(中断请求寄存器)的锁存功能失效。这样一来,在ir7ir0上的请求信号就不会被8259接收。直到第二个inta负脉冲到达8259时,才又使irr的锁存功能有效。b.使isr(服务中寄存器)中的相应位置1。c.使irr中的相应位清0。6.第二个inta负脉冲到达8259时,8259完成以下工作:a.将中断类型码(icw2中的值)送到数据总线上,cpu将其保存在“内部暂存器”中。b.如果icw4(它设定级中断联方式之特定完全嵌套方式,将在825

10、9的工作方式中详述icw4)中设置了中断自动结束方式,则将isr的相应位清0。5. ledled为发光二极管构成的显示器件,亦称数码管。由7个字符段和一个小数点段组成,每段对应一个发光二极管,当发光二极管点亮时,相应的字符段点亮。led有共阴极和共阳极两种供应状态。共阴极显示时,将led显示的com接地,将八个字符段端a、b、c、d、e、f、g、dp依次与一个8位i/o口的最低到最高位连接,当i/o给led的哪个字符段送入一个高电平时,该段就被点亮,从而可从这7个字符段中被点亮的构成相应的字符显示出来。同理,com阳极即将com端接vcc,其显示原理与com阴极的基本相同,但i/o口送入低电平

11、是相应的段才被点亮。五、 程序流程图开始初始化key1是否按下赋值子程序开中断delay子函数key2是否按下显示子函数结束nykey2按下偶数次或没按下key1被按下奇数次六、 原理图七、 心得体会八、 致谢九、 参考文献1 姚君遗汇编语言程序设计,南京大学出版社,1995 2 黄道君微型计算机原理及应用,高等教育出版社,20013 徐建民汇编语言程序设计,电子工业出版社,20024 周明德微型计算机系统原理及应用(第四版), 北京:清华大学出版社,2002,5 李芷主编微机原理与接口技术,北京:电子工业大学出版社,20026 钱晓捷汇编语言程序设计,电子工业出版社,20037 黄冰,覃伟年

12、,黄知超编著 微机原理及应用,重庆:重庆大学出版社,20038 王成端汇编语言程序设计, 高等教育出版社,20039 彭楚武 微机原理与接口技术,湖南大学出版社,200410 许曰滨汇编语言程序设计,人民邮电出版社,2005十、 附录主程序:push ds ;保存数据段mov ax,0000hmov ds,ax ;数据段清零mov ax,offset irq7 ;取中断程序入口地址add ax,2000h ;加装时ip2000地址mov si,003c ;填8259中断7中断矢量mov wsi,ax ;填偏移量矢量mov ax,0000h ;段地址cs0000hmoc si,003ehmov

13、wsi,ax ;填段地址矢量pop ds ;弹栈in al,21h ;读8259中断屏蔽字and al,7fh ;开8259中断7out 21h,almov al,39h ;8253的计数器0为方式2,采用bcd码计数,先写低8位,后写高8位。方式控制字为00110101out 43h,al ;写入方式控制字到控制字寄存器mov al,00h ;计数初值低8位out 42h,al ;写入计数初值低8位到通道0mov al,10h ;计数初值高8位out 42h,al ;写入计数初值高8位到通道0mov al,81h ;8255的a口位方式0输出,b口为方式0输出,c口下部输入1000 0001

14、out 63h,al ;写方式控制字call first ;调用first子程序,赋计数初值begi: hlt ; 延时等待sti ;开中断mov ah,01hint 16h ;检测是否按了键jz bejimov ah,00h ;读键值int 16hcmp al,0dh ;是否按了key2jnz a1mov si,4000h not si+04h ;偏移地址为4004h的内存单元内容取反jmp begia1:cmp al,1bh ;是否按了key1键jnz a2call first ;重新赋初值,相当于清零a2: jmp begi中断程序:irq7:cakk dis ;调用disp子程序,用来

15、在数码管显示数据mov si 4000hcmp si+04h,00h ;判断是否按了第2次回车键je a4call addn ;调用addn子程序,用来计数a4:mov al,20hout 20h,alcli ;关中断iret ;返回addn程序:addn:mov si,4000hadd si+05h,01h ;百分之一秒加1cmp si+05h,0ah ;判断是否大于10jz a5jmp a11a5:mov si+05h,00hadd si+04h,01h ;十分之一秒加1cmp si+04h,0ah ;判断是否大于10jz a6jmp a11a6:mov si+04h,00hadd si+

16、03h,01h ;秒位加1cmp si+03h,0ah ;判断是否大于10jz a7jmp a11a7:mov si+03h,00hadd si,01h ;十秒位加1a8:mov si+02h,00hadd si+01h,01h ;分位加1cmp si+01h,0ah ;判断是否大于10jz a7jmp a9a9:mov si+01h,00hadd si,01h ;十分位加1cmp si,06h ;判断是否大于6jz a8jmp a9a10:mov si,00 ;大于60:00重新开始a11: ret赋初值程序:first:mov si,4000hmov al,00hmovsi,al mov

17、si+01h,almov si+02h,almov si+03h,almovsi+04h,al ret显示程序:dsp: push ax;保存axmov si,4000h;指向数据缓冲区mov dl,f7h;1111 0111 指向数码管mov al,dl ;al=1111 0111again:out 60h,al;写端口amov al,simov bx,4100h ;指向数码缓冲区 bx=0100 0001 0000 0000and ax,00ffh ; bx=0000 0000 aladd bx,ax;得到显示代码 bx=0100 0001 almov al,bx out 61h,al ;写端口bc

温馨提示

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

评论

0/150

提交评论