王爽汇编-15.5代码重复执行会导致dos卡死的原因

安装新的int9中断例程的程序只能执行一次。

  • 第一次执行安装程序时,通过0:[9*4]0:[9*4+2]得到了int9csip,然后把int9csip存在了0:200h中,new_int9可以通过读取0:200h中的数据执行int9
  • 第二次执行时,和第一次执行时的逻辑相同,但是通过0:[9*4]0:[9*4+2]得到的是new_int9csip,并不是int9csip,所以第二次执行时,相当于new_int9一直在调用自身从而导致了死循环;
  • int9是指BIOS中的中断例程,new_int9是指添加了新的功能的中断例程(相当于下面代码中的int9)
assume cs:code

stack segment
    db 128 dup (0)
stack ends

code segment
start:
    mov ax,stack
    mov ss,ax
    mov sp,128

    push cs
    pop ds

    mov ax,0
    mov es,ax

    mov si,offset int9
    mov di,204h
    mov cx,offset int9_end - offset int9
    cld
    rep movsb

    push es:[9*4]
    pop es:[200h]
    push es:[9*4 + 2]
    pop es:[202h]

    cli
    mov word ptr es:[9*4],204h
    mov word ptr es:[9*4 + 2],0
    sti

    mov ax,4c00h
    int 21h

int9:
    push ax
    push bx
    push cx
    push es

    in al,60h

    pushf
    call dword ptr cs:[200h]

    cmp al,3ch
    jne int9_ret

    mov ax,0b800h
    mov es,ax
    mov bx,1
    mov cx,2000
s:  inc byte ptr es:[bx]
    add bx,2
    loop s

int9_ret:
    pop es
    pop cx
    pop bx
    pop ax
    iret

int9_end:nop

code ends
end start

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值