前回見たenable_a20関数で無事A20ゲートを有効に出来たらgo_to_protected_mode関数では次にコプロセッサをリセットするために「reset_coprocessor」関数をコールします。
arch/x86/boot/pm.c
======
static void reset_coprocessor(void){outb(0, 0xf0);io_delay();outb(0, 0xf1);io_delay();}
======
outbを使ってコマンドを出力しています。
これできっとリセットしているんでしょう。。
次に呼んでいるのは「mask_all_interrupts」です。
=====
static void mask_all_interrupts(void){outb(0xff, 0xa1); /* Mask all interrupts on the secondary PIC */io_delay();outb(0xfb, 0x21); /* Mask all but cascade on the primary PIC */io_delay();}
=====
似たようなコードですが、プライマリPIC、セカンダリPICそれぞれの割り込みに対してマスクをかけて割り込みが通知されないようにしています。
0 件のコメント:
コメントを投稿