王爽汇编语⾔检测点9.1
(1)程序如下
assume cs:code
data segment
汇编语言要什么基础
data ends
code segment
start:
mov ax, data
mov ds, ax
mov bx, 0
jmp word ptr [bx+1]
code ends
end start
若要使程序中的jmp指令执⾏后,CS:IP指向程序的第⼀条指令,在data段中应该定义哪些数据?
若要指向第⼀条指令,则要使IP的值为0000H即可,⽽jmp word ptr为段内转移指令,相当于把IP值赋值为后⾯内存单元的值,故只需要第⼀个字节为0即可。
答案:db 8 dup(0)
(2)补全程序,使得jmp指令执⾏后,CS:IP指向第⼀条指令
assume cs:code
data segment
dd 12345678H
data ends
code segment
start:
mov ax, data
mov ds, ax
mov bx, 0
mov [bx], __
mov [bx+2], __
jmp dword ptr ds:[0]
code ends
end start
由于执⾏jmp指令后指向第⼀条指令,CS段没有改变,只需要改变IP值为0000H。⽽段间转移相当于把内存地址开始的前两个字节赋值给IP,后⾯的两字节赋值给CS,按顺序填⼊0和CS值即可。
答案:bx    cs
(3)
;内存数据如下
2000:1000 BE 00 06 00 00 00 ……
;此时CPU执⾏指令
mov ax, 2000H
mov es, ax
jmp dword ptr es:[1000H]
后,(CS) = ?(IP) = ?
把前两个字节赋值给IP,后⾯的两字节赋值给CS 答案:CS = 0006H    IP = 00BEH

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。