《北科大微机原理实验报告.doc》由会员分享,可在线阅读,更多相关《北科大微机原理实验报告.doc(19页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、实验一:8259中断控制器应用实验实验名称PC机内中断应用实验成绩班级通信姓名学号实验目的: 1. 学习可编程中断控制器8259的工作原理; 2. 掌握可编程中断控制器8259的应用控制方法;实验内容: PC机中断实验。使用单次脉冲模拟中断产生。验证中断处理程序,在显示屏幕上显示一行预设定的字符串。实验步骤: 实验结果及分析:DATA SEGMENT MESS DB TPCA interrupt! ,0DH,0AH, $ DATA ENDS CODE SEGMENT ASSUME CS:CODE, DS:DATA START: MOV AX, CS MOV DS, AX MOV DX,OFFS
2、ET INT3 ;采用间接修改法 ,调用 DOS功能,设置中断向量 ,取得偏移地址 MOV AX,SEG INT3 ;通 过AX的 过渡,得到段首地址。 MOV DS,AX MOV AL,0BH ;设置 IRQ3对应的中断向量 0BH MOV AH,25H INT 21H IN AL, 21H ;读中断屏蔽寄存器,21H是该寄存器的端口号 AND AL,0F7H ;开放 IRQ3中断,允许 IRQ3的中断申请 ,11110111 OUT 21H, AL ;输出到中断屏蔽寄存器 MOV CX, 10 ;记中断循环次数为10次 STI ;允许中断发生 WAIT: JMP WAIT INT3: MO
3、V AX, DATA ;中断服务程序 MOV DS, AX MOV DX, OFFSET MESS MOV AH, 09H ;在屏幕上显示每次中断的提示信息 INT 21H MOV AL, 20H ; 发出 EOI结束中断到 PC内主片的地址 20H OUT 20H, AL LOOP NEXT ;当 CX为0,跳 转到 NEXT IN AL, 21H ;读中断屏蔽寄存器,获取中断屏蔽字 OR AL,04H ;关闭IRQ3中断 ,00000100 OUT 21H, AL ;将中断屏蔽字送到中断屏蔽寄存器 STI ;置中断标志位 MOV AH, 4CH ;返回DOS INT 21H NEXT: I
4、RET ;中断返回 CODE ENDS END START收获体会:使用间接法设置中断向量:1.将中断处理程序的段首地址送入DS寄存器,偏移量送入DX寄存器。2.将需要修改的中断向量类型号送入AL.3. 25号功能送AH。4.执行 INT 21H指令。实验名称PC机内中断嵌套实验成绩班级姓名学号实验目的: 1. 学习可编程中断控制器8259的工作原理; 2. 掌握可编程中断控制器8259的应用控制方法; 实验内容: PC机内中断嵌套实验。使用单次脉冲模拟两个中断源的中断产生,填写中断处理程序,体会中断嵌套的过程。实验步骤:实验结果及分析:CODE SEGMENT ASSUME CS:CODE
5、START:.386 ;伪指令 CLI MOV AX,CS MOV DS,AX MOV DX,OFFSET INT10 ;设置IRQ10对应的中断向量 MOV AX,SEG INT10 ;以 AX 为过渡,取得段首地址 MOV DS,AX MOV AL,72H ;IRQ10的中断向量地址为72H MOV AH,25H INT 21H MOV DX,OFFSET INT3 ;设置IRQ3对应的中断向量 MOV AX,SEG INT3 ;以 AX 为过渡,取得段首地址 MOV DS,AX MOV AL,0BH ;IRQ3的中断向量地址为0BH MOV AH,25H INT 21H IN AL,21
6、H ;读入中断控制寄存器 AND AL,0F7H ;开放 IRQ3中和 IRQ2中断请求 ,11110111 OUT 21H,AL ;输出到中断控制寄存器 IN AL,0A1H AND AL,0FBH ;开放IRQ10中断请求 11111011 OUT 0A1H,AL MOV CX,10 ;设置计数器 STI WAIT: JMP WAIT ;跳转,等待中断请求信号 INT10: CLI ;将处理器标志寄存器的中断标志位清0,当前不允许中断 PUSHAD ; 将所有的32位通用寄存器压入堆栈 PUSHFD ; 然后将32位标志寄存器EFLAGS压入堆栈 MOV CX,10 NEXT10_1: ;
7、在*号之间填写代码,在屏幕上显示10和空格的字符 ;* MOV DL,1 ;在屏幕显示字符 1 MOV AH,2 INT 21H MOV DL,0 ;在屏幕显示字符 0 MOV AH,2 INT 21H MOV DL,20H ;在屏幕显示空格字符 MOV AH,2 INT 21H ;* CALL DELAY1 ;调用延时子程序 LOOP NEXT10_1 MOV DX,0DH ;调用DOS的中断功能,回车 MOV AH,02H INT 21H MOV DX,0AH ;调用DOS的中断功能,换行 MOV AH,02H INT 21H MOV AL,20H OUT 0A0H,AL OUT 20H,
8、AL POPFD POPAD STI IRET INT3: CLI PUSHAD PUSHFD MOV CX,10 NEXT3_1: ; 在*号之间填写代码,在屏幕显示3和空格的字符 ;* MOV DL,3 ;在屏幕显示字符 3 MOV AH,2 INT 21H MOV DL,20H ;在屏幕显示空格字符 MOV AH,2 INT 21H ;* CALL DELAY1 ;调用延时子程序 LOOP NEXT3_1 MOV DX,0DH ;调用DOS的中断功能,回车 MOV AH,02H INT 21H MOV DX,0AH ;调用DOS的中断功能,换行 MOV AH,02H INT 21H MO
9、V AL,20H OUT 20H,AL OUT 0A0H,AL POPFD POPAD STI IRET DELAY1 PROC ;延时子程序 PUSHAD ; 将所有的32位通用寄存器压入堆栈 PUSHFD ; 然后将32位标志寄存器EFLAGS压入堆栈 MOV CX,0FH ;向CX送数据0FH DELAY_LOOP1: MOV BX,0FFFFH DELAY_LOOP2: DEC BX NOP JNZ DELAY_LOOP2 LOOP DELAY_LOOP1 POPFD POPAD RET DELAY1 ENDP CODE ENDS END START收获体会:(1) 按下连接IRQ的单
10、次脉冲按键,在屏幕上10次显示未结束之前,按下连接IRQ10的单次脉冲按键,观察现象;答:按下IRQ时屏幕上会显示10个3,此时按下IRQ10,会直接在屏幕上显示10个10,然后结束后再显示剩余的3(2) 按下连接IRQ10的单次脉冲按键,在屏幕上10次显示未结束之前,按下连接IRQ3的单次脉冲按键,观察现象。答:在屏幕上显示10个10的过程中按下IRQ无反应,等到10个10全部显示完毕后才再显示10个3原因:IRQ10的中断优先级比IRQ的高。实验名称扩展多中断应用实验成绩班级姓名学号实验目的: 1. 学习可编程中断控制器8259的工作原理; 2. 掌握可编程中断控制器8259的应用控制方法
11、; 实验内容: 扩展多中断源查询方式应用实验。利用实验平台上的8259控制器作为中断扩展源,编写程序对8259控制器的中断请求进行处理。 实验步骤: 实验结果及分析: ;*; 8259中断查询方式应用实验;* I8259_1 EQU 2B0H ; 8259的 ICW1端口地址 I8259_2 EQU 2B1H ; 8259的 ICW2端口地址 I8259_3 EQU 2B1H ; 8259的 ICW3端口地址 I8259_4 EQU 2B1H ; 8259的 ICW4端口地址 O8259_1 EQU 2B1H ; 8259的 OCW1端口地址 O8259_2 EQU 2B0H ; 8259的
12、OCW2端口地址 O8259_3 EQU 2B0H ; 8259的 OCW3端口地址 DATA SEGMENT MES1 DB YOU CAN PLAY A KEY ON THE KEYBOARD!,0DH, 0AH, 24H MES2 DD MES1 MESS1 DB HELLO! THIS IS INTERRUPT * 0 *!,0DH,0AH,$ MESS2 DB HELLO! THIS IS INTERRUPT * 1 *!,0DH,0AH,$ MESS3 DB HELLO! THIS IS INTERRUPT * 2 *!,0DH,0AH,$ MESS4 DB HELLO! THIS
13、 IS INTERRUPT * 3 *!,0DH,0AH,$ MESS5 DB HELLO! THIS IS INTERRUPT * 4 *!,0DH,0AH,$ MESS6 DB HELLO! THIS IS INTERRUPT * 5 *!,0DH,0AH,$ MESS7 DB HELLO! THIS IS INTERRUPT * 6 *!,0DH,0AH,$ MESS8 DB HELLO! THIS IS INTERRUPT * 7 *!,0DH,0AH,$ DATA ENDS STACKS SEGMENT DB 100 DUP(?) STACKS ENDS STACK1 SEGMENT
14、 STACK DW 256 DUP(?) STACK1 ENDS CODE SEGMENT ASSUME CS:CODE, DS:DATA, SS:STACKS, ES:DATA.386 ;伪指令,告诉编译器在本程序中使用的指令集为80386指令集 START: MOV AX,DATA MOV DS, AX MOV ES, AX MOV AX, STACKS MOV SS, AX MOV DX, I8259_1 ;初始化 8259的 ICW1 MOV AL,13H ;边沿触发、单片8259、需要ICW4 00010011 OUT DX,AL MOV DX,I8259_2 ;初始化8259的 I
15、CW2 MOV AL,0B0H OUT DX,AL MOV AL,03H OUT DX,AL MOV DX,O8259_1 ;初始化 8259的 OCW1 MOV AL,00H ;打开屏蔽位 OUT DX,AL QUERY: MOV AH,1 ;判断是否有按键按下 INT 16H JNZ QUIT ;有按键则退出 MOV DX,O8259_3 ;向 8259的 OCW3发送查询命令 MOV AL,0CH ;0000 1100 D2=1,设置为中断查询方式工作 OUT DX,AL IN AL,DX ;读出查询字 MOV AH,AL AND AL,80H ;判断中断是否已响应 TEST AL,80
16、H JZ QUERY ;没有响应则继续查询 MOV AL,AH AND AL,07H ;取出查询字的末三位 00000111 ;通过下面的比较判断程序,判断中断请求来自哪个优先级 CMP AL,00H ;将查询字末三位与00H比较,相等,为IR0请求 JE IR0ISR ;若为IR0请求,跳到 IR0处理程序 CMP AL,01H JE IR1ISR ;若为IR1请求,跳到 IR1处理程序 CMP AL,02H JE IR2ISR ;若为IR2请求,跳到 IR2处理程序 CMP AL,03H JE IR3ISR ;若为IR3请求,跳到 IR3处理程序 CMP AL,04H JE IR4ISR
17、;若为IR4请求,跳到 IR4处理程序 CMP AL,05H JE IR5ISR ;若为IR5请求,跳到 IR5处理程序 CMP AL,06H JE IR6ISR ;若为IR6请求,跳到 IR6处理程序 CMP AL,07H JE IR7ISR ;若为IR7请求,跳到 IR7处理程序 JMP QUERY IR0ISR: MOV AX,DATA ;将数据段首地址放入 AX寄存器 MOV DS,AX MOV DX,OFFSET MESS1 ;显示提示信息 MOV AH,09 INT 21H JMP EOI IR1ISR: MOV AX,DATA MOV DS,AX MOV DX,OFFSET ME
18、SS2 ;显示提示信息 MOV AH,09 INT 21H JMP EOI IR2ISR: MOV AX,DATA MOV DS,AX MOV DX,OFFSET MESS3 ;显示提示信息 MOV AH,09 INT 21H JMP EOI IR3ISR: MOV AX,DATA MOV DS,AX MOV DX,OFFSET MESS4 ;显示提示信息 MOV AH,09 INT 21H JMP EOI IR4ISR: MOV AX,DATA MOV DS,AX MOV DX,OFFSET MESS5 ;显示提示信息 MOV AH,09 INT 21H JMP EOI IR5ISR: MO
19、V AX,DATA MOV DS,AX MOV DX,OFFSET MESS6 ;显示提示信息 MOV AH,09 INT 21H JMP EOI IR6ISR: MOV AX,DATA MOV DS,AX MOV DX,OFFSET MESS7 ;显示提示信息 MOV AH,09 INT 21H JMP EOI IR7ISR: MOV AX,DATA MOV DS,AX MOV DX,OFFSET MESS8 ;显示提示信息 MOV AH,09 INT 21H EOI: MOV DX,O8259_2 ;向 8259 的 OCW2发送中断结束命令 MOV AL,20H ;00100000 D5
20、=1,中断结束 OUT DX,AL JMP QUERY QUIT: MOV AX,4C00H ;结束程序退出 INT 21H CODE ENDS END START收获体会:所填数据的形成原理:1.MOV AL, 13H ;边沿触发,单片8259,需要ICW4解释:在初始化ICW1中,D7D5都是0. D4=1,是ICW1. D3=0,上升沿触发。D2=0, 8086中固定设为0. D1=1,单片工作方式。 D0=1,需要ICW4。所以ICW1=00010011B=13H2.MOV AL,00H ;打开屏蔽位。解释:中断屏蔽寄存器中,某一位为0时允许中断,为1时屏蔽中断。3.MOV DX,O8
21、259_3 ;向8259的OCW3发送查询命令。MOV AL,L,0CH ;0000 1100 D2=1,设置为中断查询方式工作.4.AND AL,80H ;判断中断是否已响应 解释:取得AL的最高位,判断是1或0.5.MOV DX,O8259_2 ;向 8259 的 OCW2发送中断结束命令MOV AL,20H ;00100000 D5=1,中断结束解释:OCW2的D5=1时,中断结束。 思考题:1. 单中断和多中断有何不同? 单中断就是从中断开始到中断结束只能完成一次中断,多中断应该是多重中断,这种中断方式可以允许在一次中断未完成时响应更高级别的中断申请,也叫中断嵌套。2. 如何改变中断优
22、先级的顺序?可以根据程序中中断的书写顺序和逻辑结构来进行判断。3. 可编中断控制寄存器8259A在协助CPU处理中断事务中起到那些作用?1优先级排队管理根据任务的轻重缓急或设备的特殊要求,分配中断源的中断等级。8259A具有完全嵌套。循环优先级、特定屏蔽等多种方式的优先级排队管理。2可屏蔽中断INTR当CPU的INTR引脚上有一个来自外部的“高”有效信号输人时,则产生硬件可屏蔽中断请求INTR,这种请求可以被CPU用指令CLI来禁止,也可由指令STI来允许。只有在INTR被允许时,CPU才发中断响应信号INTA,这时,中断源一定要向CPU提供中断类型号,以便找到中断服务程序入口。中断向量表中中
23、断号为080FH和070H077H的中断,属于这种中断(见表5.2)。很明显,这种中断是由外部设备产生的。 3提供中断类型号8259A最突出的特点是具有对中断服务程序入口地址的寻址能力,也就是当CPU响应中断申请后,通过8259A提供的中断类型号可以找到中断服务程序的人口地址,转移到中断服务程序去执行。4进行中断请求的屏蔽和开放8259A能够对提出中断请求的外部设备进行屏蔽或开放。可见,采用8259A可使系统的硬中断管理无需附加其他电路,只需对8259A进行编程,就可管理8级、15级或更多的硬中断,并且还可实现向量中断和查询中断4. 可屏蔽中断与8259A是什么关系?一片Intel 8259可
24、管理8个中断请求,并把当前优先级最高的中断请求送到CPU的INTR端;并在CPU响应中断时,为CPU提供中断类型码;8个外部中断的优先级排列方式,可以通过对8259编程进行指定。也可以通过编程屏蔽某些中断请求,或者通过编程改变中断类型码。允许9片8259级联,构成64级中断系统。中断可分为可屏蔽中断与不可屏蔽中断。其中可屏蔽中断是外设使用最多的中断方式。实验二:8255并口控制应用实验实验名称可编程并行接口8255方式0应用实验成绩班级姓名学号实验目的: 1. 掌握8255的工作方式及应用编程; 2. 掌握8255典型应用电路的接法。实验内容:1.基本输入输出实验。编写程序,使8255的B口为
25、输入,A口为输出,完成拨动开关到数据灯的数据传输。要求只要开关拨动,数据灯的显示就改变。实验步骤:实验结果及分析: IO8255_MODE EQU 28BH IO8255_A EQU 288H IO8255_B EQU 289H CODE SEGMENT ASSUME CS: CODE START: MOV DX, IO8255_MODE ;设8255为 B口输入,A口输出 MOV AL,82H ;设置控制字为10000010B OUT DX, AL INOUT: MOV DX, IO8255_B ;从 B口读入数据 IN AL,DX MOV DX,IO8255_A ;从 A口输出数据 OUT
26、 DX,AL MOV DL,0FFH ;判断是否有按 键 MOV AH, 06H INT 21H JZ INOUT ;若无,则继续自B口输入,A口输出 MOV AH,4CH ;否则返回 INT 21H CODE ENDS END START收获体会:8255芯片需要设置好控制字,然后进行读写控制操作。实验名称流水灯实验成绩班级姓名学号实验目的: 1. 掌握8255的工作方式及应用编程; 2. 掌握8255典型应用电路的接法。实验内容:流水灯显示实验。编写程序,使8255的A口为输出,数据灯D7D0由左向右,每次仅亮一个灯,循环显示。实验步骤:实验结果及分析: IO8255_A EQU 288H ;8255的 A口地址 IO8255_MODE EQU 28BH ;8255的控制寄存器地址 STACK1 SEGMENT STACK DW 256 DUP(?) STACK1 ENDS DATA SEGMENT LA DB ? ;定义数据变量 DATA ENDS CODE SEGMENT ASSUME CS:CODE, DS:DATA START: MOV AX, DATA MOV