0
我正在使用N450开发板,事实证明它已经有IDT(也许是由BIOS !!构建的)。 当我使用INT $ 0x55(使用ItnCall)调用ISR时,代码跳转到另一个随机地址而不是跳到ISR_0x55 !!!为什么?使用IDT(INTERRUPT DESCRIPTOR TABLE)程序集AT&T intel 32位
这是我的代码:
C代码
fill_interrupt(ISR_0x55,
(unsigned int) isr0x55, //
0x10, // Segment Selector
0x8E); // P=1, DPL=0, D=1
static void fill_interrupt(unsigned char num, unsigned int base, unsigned short sel, unsigned char flags)
{
unsigned short *Interrupt_Address;
/*address = idt_ptr.base + num * 8 byte*/
Interrupt_Address = (unsigned short *)(idt_ptr.base + num*8);
*(Interrupt_Address) = base&0xFFFF;
*(Interrupt_Address+1) = sel;
*(Interrupt_Address+2) = (flags<<8)&0xFF00;
*(Interrupt_Address+3) = (base>>16)&0xFFFF;
}
汇编代码
IntCall:
push %ebp //save the context to swith back
movl %esp,%ebp
//debug only
nop
nop
//debug only
int $0x55
pop %ebp //Return to the calling function
ret
你为'0x10'设置了哪些段描述符?这里的'0x08'是一个更常见的值。 – user786653
CS区块是0x10 –
那么,它跳转到的“随机地址”是什么?你有没有堆栈跟踪或注册转储? – user786653