| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
x
 
 本帖最后由 hhhi 于 2021-4-23 17:35 编辑  
 
(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 8dup(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 
 
 
 
———————————————— 
版权声明:本文为CSDN博主「dantkv」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 
原文链接:https://blog.csdn.net/dankst/article/details/86028855 |   
 
 
 
 |