0

我在 Atom-32bit-intel 上工作,我必须移植 MicroC OS II,所以没有代码可以在 Atom 上进行任何配置(没有 GDT,没有 LDT ...):

我的问题更多是关于重置后 Atom-32bit 的状态,Atom 是否处于保护模式?最重要的是我如何检查它是哪种模式(必须检查哪些寄存器以及如何检查)?

备注:CR0.PE = 1(我检查过),这足以证明 Atom 处于保护模式吗?

* ** * ** * ** * **更新 :** * ** * ** * ** * ** * **

    /*Read the IDTR*/
    sidt (idt_ptr)

    /*Read the GDTR*/
    sgdt (gdt_ptr)

所以我尝试使用 IDT 的地址将我的 ISR 链接到 IDT:

fill_interrupt(ISR_Nbr,(unsigned int) isr33, 0x08, 0x8E);

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+1) = (flags>>8)&0xFF00;
    *(Interrupt_Address+1) = (base>>16)&0xFFFF;

}

我的 ISR 是一个简单的 ISR:

isr33:
nop
nop
cli
push %ebp   //save the context to swith back
mov %esp,%ebp




pop %ebp //Return to the calling function
sti
ret
4

3 回答 3

2

英特尔软件开发人员手册第 3 卷第 9 章说 的重置CR0值为60000010H。如您所见,位 0,即 PE,是明确的。

无论如何,您可以在保护模式和实模式下设置描述符表。你只需要更加小心。


我建议您在阅读之前先检查一下 BIOS 或操作系统是否设置了此位。

于 2011-10-04T20:28:44.627 回答
1

Atom 是 x86 指令集,因此,为了兼容性,应该以实模式启动。我手头没有一个可以测试。

于 2011-10-04T20:30:57.877 回答
0

解决了,我用的是N450 Atom板,它已经有BIOS了,BIOS将板子配置为保护模式。

于 2011-11-14T15:27:05.233 回答