熊文杰 发表于 2013-4-22 18:15:36

第12章 iret使用疑惑

第十二章的0号中断处理程序,如下:
assume cs:code

code segment
start:       
                mov ax, cs
                mov ds, ax
                mov si, offset do0                ;设置ds:si指向源地址
                mov ax, 0
                mov es, ax
                mov di, 200h                        ;设置es:di指向目的地址
                mov cx, offset do0end - offset do0                ;设置cx为传输长度
                cld                                        ;设置传输方向为正
                rep movsb
               
                mov ax, 0               ;设置中断向量表
                mov es, ax
                mov word ptr es:, 200h
                mov word ptr es:, 0

              mov ax,4c00h
              int 21h

do0:        jmp short do0start
              db "Welcome to Fishc.com!"

do0start:
              mov ax, cs
              mov ds, ax
              mov si, 202h                        ;设置ds:si指向字符串

              mov ax, 0b800h
              mov es, ax
                mov di, 12*160+36*2                ;设置es:di指向显存空间的中间位置

      mov cx, 21                                ;设置cx为字符串长度
        s:        mov al,
              mov es:, al
              inc si
              add di, 1
                mov al, 02h             ;设置颜色
                mov es:, al      
                add di, 1
              loop s
               
                iret;      返回到源程序继续向下执行
               
              mov ax, 4c00h
              int 21h
do0end:        nop

code ends
end start


另外一个触发0号中断的程序如下

assume cs:codesg

codesg segment

start:
        mov ax,1000h
        mov bh,1;
        div bh

       
        mov cx,1000h;
       
        mov ax,4c00h
        int 21h
codesg ends
end start;



首先执行0号中断的处理程序,然后执行上面这个除法溢出程序。debug跟踪到iret时候,又跳转到了div bh,这条指令。。。

按照第三章中 ip自加的时机来说,在执行div bh指令之前ip就应该自加了。那为什么iret会返回div bh的地址呢?

熊文杰 发表于 2013-4-22 23:31:02

难道是我的环境有问题,还是只有int 0是特殊的? 编写十三章的例子是没有问题。蛋疼
页: [1]
查看完整版本: 第12章 iret使用疑惑