实验4 8086标志寄存器及中断
实验内容
1. 实验任务1
•task1.asm源码
assume cs:code, ds:data data segment x dw 1020h, 2240h, 9522h, 5060h, 3359h, 6652h, 2530h, 7031h y dw 3210h, 5510h, 6066h, 5121h, 8801h, 6210h, 7119h, 3912h data ends code segment start: mov ax, data mov ds, ax mov si, offset x mov di, offset y call add128 mov ah, 4ch int 21h add128: push ax push cx push si push di sub ax, ax mov cx, 8 s: mov ax, [si] adc ax, [di] mov [si], ax inc si inc si inc di inc di loop s pop di pop si pop cx pop ax ret code ends end start
•回答问题 line31~line34的4条inc指令,能否替换成如下代码?你的结论的依据/理由是什么?
能,inc指令不会改变标志寄存器的内容,add可能会改变标志寄存器的内容(指令add/sub的执行会影响到CF, PF, AF, ZF, SF, OF),但在这道题中,因为数据没有产生进位,所以可以使用。
•在debug中调试,观察数据段中做128位加之前和加之后,数据段的值的变化。给出调试观察截图。


2. 实验任务2
•程序task2.asm源码
assume cs:code, ds:data data segment str db 80 dup(?) data ends code segment start: mov ax, data mov ds, ax mov si, 0 s1: ;输入字符,遇到#为止 mov ah, 1 int 21h ;在屏幕上输入一个字符,放入al中 mov [si], al ;输入字符传入data中 cmp al, '#' je next inc si jmp s1 next: mov ah, 2 ;换行 mov dl, 0ah int 21h mov cx, si mov si, 0 s2: mov ah, 2 ;输出dl中的内容 mov dl, [si] int 21h inc si loop s2 mov ah, 4ch int 21h code ends end start
•运行测试截图

• 回答问题
① 汇编指令代码line11-18,实现的功能是?
从屏幕中输入一个字符,如果不是#则继续输入,是#则跳到next段
② 汇编指令代码line20-22,实现的功能是?
输出一个换行键
③ 汇编指令代码line24-30,实现的功能是?
将输入的所有字符(除#外)全部输出到屏幕上
3. 实验任务3
• task3.asm源码
assume cs:code,ds:data data segment x dw 91,792,8536,65521,2021 len equ $-x data ends ;被除数在AX 或者 AX和DX中,当除数为8位时,商存放在AL寄存器中, ;余数存放在AH寄存器中,当除数为16位时,商在AX中,余数在DX中 code segment start: mov ax,data mov ds,ax mov si,0 mov cx,len/2 s: mov ax,ds:[si] call printNumber call printSpace inc si inc si loop s mov ah,4ch int 21h printNumber: push cx mov bx,10 mov di,0 p: mov dx,0 div bx push dx inc di cmp ax,0 jne p mov ah,2 mov cx,di m: pop dx or dl,30h int 21h loop m pop cx ret printSpace: mov ah,2 mov dl,20h int 21h ret code ends end start
• 运行测试截图

4. 实验任务4
•task4.asm源码
assume cs:code,ds:data data segment str db "assembly language, it's not difficult but tedious" len = $-str data ends code segment start: mov ax,data mov ds,ax mov si,0 mov cx,len p: call strupr inc si loop p mov ah,4ch int 21h strupr: cmp byte ptr ds:[si],'a' jb s cmp byte ptr ds:[si],'z' ja s mov bl,ds:[si] sub bl,32 mov ds:[si],bl s: ret code ends end start
•在debug中调试截图( call strupr 调用之前,数据段的值,以及,调用之后,数据段的值)


5. 实验任务5
•task5.asm源码
assume cs:code, ds:data data segment str1 db "yes", '$' str2 db "no", '$' data ends code segment start: mov ax, data mov ds, ax mov ah, 1 int 21h mov ah, 2 mov bh, 0 mov dh, 24 mov dl, 70 int 10h cmp al, '7' je s1 mov ah, 9 mov dx, offset str2 int 21h jmp over s1: mov ah, 9 mov dx, offset str1 int 21h over: mov ah, 4ch int 21h code ends end start
•程序运行测试截图(输入7,以及输入其他字符,运行结果截图)


•程序的功能是?
判断从键盘输入的字符是否是7,如果是7返回yes,否则返回no
6. 实验任务6
•通过此项实现任务,你对中断、软中断实现机制的理解
实现中断主要通过设置中断向量与实现函数功能。中断向量是指中断服务程序入口地址的偏移量与段基值,一个中断向量占据4字节空间,它的作用就是按照中断类型号从小到大的顺序存储对应的中断向量,通过中断向量存储函数实现的代码段。代码段可以通过自己设置位置,在其中,可以使用各种寄存器实现所需要的功能。
•自己选一个未被使用的中断码,实现一个中断例程,并调用测试。给出源码和运行测试截图。
assume cs:code code segment start: ; 42 interrupt routine install code mov ax, cs mov ds, ax mov si, offset int241 ; set ds:si mov ax, 0 mov es, ax mov di, 200h ; set es:di mov cx, offset int241_end - offset int241 cld ;使df值为0(df为0,向高地址增加,df为1,向低地址减小) rep movsb ;把 DS:SI 所指地址的一个字节搬移到 ES:DI 所指的地址上,rep重复执行 ; set IVT(Interrupt Vector Table) mov ax, 0 mov es, ax mov word ptr es:[241*4], 200h mov word ptr es:[241*4+2], 0;中断服务程序入口地址的偏移量与段基值,一个中断向量占据4字节空间。 mov ah, 4ch int 21h int241: jmp short int241_start str db "welcome to humingtao!" len equ $ - str ; display string "welcome to 2049!" int241_start: mov ax, cs mov ds, ax mov si, 202h mov ax, 0b800h mov es, ax mov di, 24*80 + 32*2 mov cx, len s: mov al, [si] mov es:[di], al mov byte ptr es:[di+1], 1 inc si add di, 2 loop s iret ;中断返回,中断服务程序的最后一条指令 int241_end: nop ;运行该指令时单片机什么都不做,但是会占用一个指令的时间 code ends end start
assume cs:code code segment start: int 241 mov ah, 4ch int 21h code ends end start


浙公网安备 33010602011771号