|
10鱼币
第十二章的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:[0*4], 200h
mov word ptr es:[0*4+2], 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, [si]
mov es:[di], al
inc si
add di, 1
mov al, 02h ;设置颜色
mov es:[di], 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的地址呢?
|
|