实验3 转移指令跳转原理及其简单应用编程
-
实验结论
-
实验任务1
task1源码
1 assume cs:code, ds:data 2 3 data segment 4 x db 1, 9, 3 5 len1 equ $ - x 6 7 y dw 1, 9, 3 8 len2 equ $ - y 9 data ends 10 11 code segment 12 start: 13 mov ax, data 14 mov ds, ax 15 16 mov si, offset x 17 mov cx, len1 18 mov ah, 2 19 s1:mov dl, [si] 20 or dl, 30h 21 int 21h 22 23 mov dl, ' ' 24 int 21h 25 26 inc si 27 loop s1 28 29 mov ah, 2 30 mov dl, 0ah 31 int 21h 32 33 mov si, offset y 34 mov cx, len2/2 35 mov ah, 2 36 s2:mov dx, [si] 37 or dl, 30h 38 int 21h 39 40 mov dl, ' ' 41 int 21h 42 43 add si, 2 44 loop s2 45 46 mov ah, 4ch 47 int 21h 48 code ends 49 end start
运行截图

问题①:line27, 汇编指令 loop s1 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明 是如何计算得到跳转后标号s1其后指令的偏移地址的。
机器码:E2F2
跳转位移量:-14
计算方法:F2转十进制为-14,下一条指令的偏移地址为001B,转为十进制为27,27-14=13。13转为16进制为000D。
问题②:line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机 器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明 是如何计算得到跳转后标号s2其后指令的偏移地址的。
机器码:E2F0
跳转位移量:-16
计算方法:F0转十进制为-16,下一条指令的偏移地址为0039,转为十进制为57,57-16=41。41转为16进制为0029。
问题③:附上上述分析时,在debug中进行调试观察的反汇编截图
问题①反汇编截图:

问题②反汇编截图

-
试验任务2
task2源码
1 assume cs:code, ds:data 2 3 data segment 4 dw 200h, 0h, 230h, 0h 5 data ends 6 7 stack segment 8 db 16 dup(0) 9 stack ends 10 11 code segment 12 start: 13 mov ax, data 14 mov ds, ax 15 16 mov word ptr ds:[0], offset s1 17 mov word ptr ds:[2], offset s2 18 mov ds:[4], cs 19 20 mov ax, stack 21 mov ss, ax 22 mov sp, 16 23 24 call word ptr ds:[0] 25 s1: pop ax 26 27 call dword ptr ds:[2] 28 s2: pop bx 29 pop cx 30 31 mov ah, 4ch 32 int 21h 33 code ends 34 end start
① 根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,寄存器(ax) = ? 寄存器(bx) = ? 寄存器(cx) = ?
因为ax中的值为s1的IP,bx中的值为s2的IP,cx中的值为s2的CS
ax=0021
bx=0026
cx=076C
② 对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试 结果与理论分析结果是否一致。

一致
-
试验任务3
task3源码
1 assume ds:data, cs:code 2 data segment 3 x db 99, 72, 85, 63, 89, 97, 55 4 len equ $- x 5 data ends 6 7 code segment 8 start: 9 mov ax, data 10 mov ds, ax 11 mov si, offset x 12 mov cx, len 13 mov byte ptr ds:[10], 10 14 15 s1: mov ah, 0 16 mov al, ds:[si] 17 18 div byte ptr ds:[10] 19 call printNumber 20 call printSpace 21 inc si 22 loop s1 23 24 mov ax, 4c00h 25 int 21h 26 27 printNumber:mov bx, ax 28 or bl, 30h 29 or bh, 30h 30 mov ah, 2 31 mov dl, bl 32 int 21h 33 mov dl, bh 34 int 21h 35 ret 36 37 printSpace:mov ah, 2 38 mov dl, ' ' 39 int 21h 40 ret 41 42 code ends 43 end start

-
试验任务4
task4源码
1 assume cs:code, ds:data 2 3 data segment 4 str db 'try' 5 len equ $ - str 6 data ends 7 8 code segment 9 start: 10 mov ax,data 11 mov ds,ax 12 13 mov cx,len 14 mov si,offset str 15 mov bh,0 16 mov bl,2 17 call printStr 18 19 mov cx,len 20 mov si,offset str 21 mov bh,24 22 mov bl,4 23 call printStr 24 25 mov ah,4ch 26 int 21h 27 printStr: 28 mov al,0ah 29 mul bh 30 add ax,0b800h 31 mov es,ax 32 33 mov di,si 34 s: mov al,ds:[si] 35 mov ah,bl 36 mov es:[di],ax 37 inc si 38 add di,2 39 loop s 40 ret 41 code ends 42 end start

-
试验任务5
task5源码
1 assume cs:code, ds:data 2 3 data segment 4 stu_no db '201983290057' 5 len = $ - stu_no 6 data ends 7 8 code segment 9 start: 10 mov ax, data 11 mov ds, ax 12 mov ax,0B800H 13 mov es,ax 14 15 mov cx,0780H; 16 mov ah,10H 17 mov al,' ' 18 mov bx,0 19 s: mov es:[bx],ax 20 add bx,2 21 loop s 22 23 mov cx,80; 24 mov ah,17H 25 mov al,'-' 26 s1: mov es:[bx],ax 27 add bx,2 28 loop s1 29 30 mov cx,len; 31 mov bx,0F44H 32 mov si,0 33 s2: mov al,[si] 34 mov es:[bx],ax 35 inc si 36 add bx,2 37 loop s2 38 39 mov ah, 4ch 40 int 21h 41 42 code ends 43 end start

-
实验总结

浙公网安备 33010602011771号