英特尔IAPX88处理器,陷阱ISR

时间:2010-07-21 17:23:27

标签: assembly nasm interrupt-handling tsr

我发布了下面这段代码,这段代码的基本目标是,当我将陷阱标志设置为1然后我在屏幕上打印字符z后,现在设置了陷阱标志,程序应该执行一个指令和陷阱,我写了一个简单的陷阱ISR,其中我有一个无限循环,如果按下F2键,这个无限循环将被打破,因为你可以看到键盘中的F2键的扫描码是名为kbisr的程序。 这是我希望从这个程序中实现的功能,但它没有这样做,请检查这个代码并告诉我我做错了什么。这是代码

[org 0x100]
jmp start

flag: db 0

kbisr:  push ax
 push cs
 pop ds

 in al,0x60 ; reading keyboard port
 cmp al,60 ; comparing it with scan code of F2
 jne skip ; if not F2 then do nothing

 mov byte[flag],1


skip: pop ax

; signlaing end of interrupt
 mov al,0x20
 out 0x20,al
 iret

; subroutin to clear the screen
clrscr: push ax
 push bx
 push es
 push di
 push cx

 mov ax,0xb800
 mov es,ax
 mov cx,4000
 mov ax,0x0720
 rep stosw
 pop cx
 pop di
 pop es
 pop bx
 pop ax
 ret

; the trap ISR

trap: push ax
 push bx
 push cx
 push dx
 push es
 push ss
 push ds
 push cs
 push di
 push si
 push bp


push cs
pop ds  ; initializing the data segment
sti
call clrscr 
mov byte[flag],0
l1: cmp byte[flag],0 ; infinite loop, waiting for F2
 je l1
 pop bp
 pop si
 pop di
 pop cs
 pop ds
 pop ss
 pop es
 pop dx
 pop cx
 pop bx
 pop ax

 iret

start: 

 mov ax,0
 mov es,ax

; hooking the trap interrupt

 mov word[es:1*4],trap
 mov word[es:1*4+1],cs
;now hooking the keyboard interrupt
 cli
 mov word[es:9*4],kbisr
 mov word[es:9*4+2],cs
 sti
 mov cx,0xb800
 mov es,cx
 mov di,10
 mov ch,0x05
 mov cl,'z'
;setting the trap flag to 1
 pushf
 pop bx
 or bx,0x100
 push bx
 popf
; now trap flag is on

 mov word[es: di],cx
 add di,2
 mov word[es: di],cx
 add di,2
;residing the program in memory after termination so this is a TSR
 mov dx,start
 add dx,15
 shr dx,4
 mov ax,0x3100
 int 0x21

1 个答案:

答案 0 :(得分:0)

你错了这句话:

 mov word[es:1*4+1],cs

应该是:

 mov word[es:1*4+2],cs

修改: 什么是

pop cs

应该做什么?

实际上,令我惊讶的是,nasm没有抱怨过这个。