2011-10-21 8 views
0

N450ボードで作業していますが、すでにIDT(BIOSで構築されているかもしれません!! INT $ 0x55(ItnCallを使用)を使用して自分のISRを呼び出すと、コードはISR_0x55にジャンプするのではなく、別のランダムアドレスにジャンプします。IDT(割り込みデスクリストテーブル)アセンブリを使用する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 
+0

あなたは '0x10'にどのようなセグメント記述子を設定しましたか? '0x08'はここでIIRCのより一般的な値です。 – user786653

+0

CSセグメンテーションは0x10 –

+0

です。まあ、ジャンプ先の「ランダムアドレス」は何ですか?スタックトレースやレジスタダンプはありますか? – user786653

答えて

0

、ちょうどブレークポイント、私は、ISRの内部でデバッガをブレークポイントを置きますそれを好きではありません

関連する問題