酒鬼 发表于 2015-6-12 19:32:08

第六章 实验5-1 有疑问0.0

本帖最后由 酒鬼 于 2015-6-13 10:54 编辑

我在单步跟踪这一题的时后有一个疑问

我在:mov ax,stack
        mov ss,ax
        mov sp,16

SS得到我的栈地址后
SS:0B3E,SP:0010
我用 Debug 的D指令去查 d 0B3E:0000

在我画线的部份 为啥不是都为0 而是有数据在的???

我不是已经stack segment
                        dw 0,0,0,0,0,0,0,0
                   stack ends
声请好了8个字形数据的位置都为0麻??



assume cs:code,ds:data,ss:stack

data segment
        dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
data ends

stack segment
        dw 0,0,0,0,0,0,0,0
stack ends

code segment
        Start:
                mov ax,stack
                mov ss,ax
                mov sp,16
               
                mov ax,data
                mov ds,ax
               
                push ds:
                push ds:
                pop ds:
                pop ds:
                       
                mov ax,4c00h
                int 21h
code ends

        end Start

酒鬼 发表于 2015-6-29 19:29:13

時隔多日,都沒人能回答我的一或呀0.0
不過有一件值得慶幸的是
那就是經過了這麼多天,我已經學習到了 第十二章 內中斷
因為這樣我才終於在這一章中找到了當初的疑問的答案
在此分享一下~~

每當在Debug程序中 執行一次T指令
內部將會做以下事情

取得中斷類型碼N
pushf
TF,IF設置為0
push cs
push ip
IP = N*4
CS = (N*4)+2

最後在
iret

iret等於以下

pop IP
pop CS
popf

各位看出原因了嗎??

在我們輸入T指令,內部去執行完設置SS,SP的任務後
再跑去執行一些中斷代碼
其中就包括了最關鍵的
將標誌寄存器與CS,IP推入棧中保存起來
之後再將他們取出來

所以在執行完T指令後
我們的IP並沒有走位,依然是我們設定的數值
但棧裡面的值被改變了
也就是標誌寄存器與CS,IP的值拉!!!!!!!!!!!!!

fast 发表于 2015-7-6 06:53:23

继续努力,加油
页: [1]
查看完整版本: 第六章 实验5-1 有疑问0.0