2012-12-15 36 views
0

我正在尝试创建处理键盘输入的硬件中断处理程序。问题是我的处理程序只有在Receiver Control Register的值为1时才会继续运行。目前,我的代码的值为3,因此我的处理程序只是退出,因为我只想处理硬件中断。我无法在网上找到任何描述什么是3级中断的地方,以及我如何修复我的代码,以便提供1级中断。什么是接收器控制寄存器的中断级别

有人能告诉我什么级别3或至少指向我的资源?谢谢

要添加到此。我也得到了256作为我的原因寄存器的值。我认为所有的代码都是十六进制的,因此这将是一个代码4.我能看到的是来自非法地址的加载。这是没有道理的,因为直到我敲击键盘上的某个键时,中断处理程序才被调用。继承人代码:

.data 0xffff0000 
RecvCtrlReg: .word 0 

.ktext 0x80000180 

    #move $k1, $at 

    #la $k0, frogger # save the address to frogger function for long call 

    mfc0 $k1, $13 
    beq $k1, 0, keyboard # If cause register is not zero, exit 

    li $v0, 10  # Do nothing and exit 
    syscall 

    keyboard:   # else check interupt level 

    lw $t7, RecvCtrlReg  
    beq $t7, 1, continue # if the Reciever Control Reg is 1, its a hardware interrupt, so continue 

    li $v0, 10  # else do nothing and exit 
    syscall 
    continue: 

    jalr $k0  # long call frogger function 

    mtc0 $0, $13  # set cause register to 0 

    mfc0 $k0, $12  # Fix status register 
    andi $k0, 0xfffd # clear EXL bit 
    ori $k0, 0x1  # Enable interrupts 
    mtc0 $k0, $12  # Store value back into status register 

    #move $at, $k1 

    eret 

回答

0

它不仅仅是Cause寄存器中断位字段的单独足以接受请求。通常,Cause寄存器的中断字段也与Status寄存器的中断字段进行位逻辑与运算。结果位与OR位在一起,并且值与Status寄存器的IE位(主器件使能用于中断)的位相同会引起中断。