鱼C论坛

 找回密码
 立即注册
查看: 3024|回复: 4

[已解决]这个汇编我很迷!???

[复制链接]
发表于 2020-4-9 10:36:03 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 百里狂生 于 2020-4-9 11:00 编辑
assume cs:code,ss:stack

stack segment
        dw 8 dup(0)
stack ends

code segment
start:
        mov ax,stack
        mov ss,ax
        mov sp,16
        mov ds,ax
        mov ax,0
        call word ptr ds:[0eH]
        inc ax
        inc ax
        inc ax

code ends
end start
为什么单步调试的时候,执行完mov ss,ax ,栈区(或data区)的值发生了改变?不是没有指令做修改吗?见图1
为什么call word ptr ds:[0eH]执行完后,不是跳转到(ds:[0eH])所在的位置,而是一个不知道哪来的位子?见图2
最佳答案
2020-4-9 13:04:18
在我这边
call word ptr ds:[0eH]
这条call指令调用的是第一条指令
mov ax,stack

call word ptr ds:[0eH]
这条指令转移的目标位置就是这个位置的值 ds:[0eH],是执行call之前的值,是push ip之前的值
在我这边,push ip之前 ds:[0eH] 的内容是0,所以转移到了 0x16f0:0,而这个位置正好保存了第一条指令 mov ax,stack
这也不是绝对的,这里保存的也完全可以是其他指令
而且执行call指令之前,你用debug调试,debug用到了中断机制,中断机制用到了栈,也就是  ds:[0eH] 这个位置的值已经不是0,至于程序会转移到哪里,谁也不知道(或许这个值有规律?不重要了,^_^)

下面是我的调试过程,用了更高级的调试工具,bochs,debug做不到的事,bochs可以
1.png

图1

图1

图2

图2
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-9 12:12:33 | 显示全部楼层

回帖奖励 +2 鱼币

为什么单步调试的时候,执行完mov ss,ax ,栈区(或data区)的值发生了改变?不是没有指令做修改吗?
因为你在用debug这个程序调试程序,debug这个程序要实现调试其他程序,需要用到中断机制,中断机制要用到栈
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-9 12:15:17 | 显示全部楼层
这个代码哪来的?要实现什么功能?

第二个问题我研究研究
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-9 13:04:18 | 显示全部楼层    本楼为最佳答案   
在我这边
call word ptr ds:[0eH]
这条call指令调用的是第一条指令
mov ax,stack

call word ptr ds:[0eH]
这条指令转移的目标位置就是这个位置的值 ds:[0eH],是执行call之前的值,是push ip之前的值
在我这边,push ip之前 ds:[0eH] 的内容是0,所以转移到了 0x16f0:0,而这个位置正好保存了第一条指令 mov ax,stack
这也不是绝对的,这里保存的也完全可以是其他指令
而且执行call指令之前,你用debug调试,debug用到了中断机制,中断机制用到了栈,也就是  ds:[0eH] 这个位置的值已经不是0,至于程序会转移到哪里,谁也不知道(或许这个值有规律?不重要了,^_^)

下面是我的调试过程,用了更高级的调试工具,bochs,debug做不到的事,bochs可以
1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-9 14:54:31 | 显示全部楼层
人造人 发表于 2020-4-9 13:04
在我这边
call word ptr ds:[0eH]
这条call指令调用的是第一条指令

非常感谢,终于知道原因了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-5 22:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表