X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?a=blobdiff_plain;f=src%2Fkmain.c;h=8af7cc37fa4a090d90b9a4d74f0db3d98a78eea3;hb=81c11bdd80190ec319a82b0402173cfb65fcbf72;hp=0ffc152bd71719a8a21284f543ae6e5d379fc345;hpb=91fc6b749ad3a64c9a2686952eb30be517c6beb9;p=bootcensus diff --git a/src/kmain.c b/src/kmain.c index 0ffc152..8af7cc3 100644 --- a/src/kmain.c +++ b/src/kmain.c @@ -20,10 +20,15 @@ along with this program. If not, see . #include #include "segm.h" #include "intr.h" +#include "mem.h" #include "keyb.h" +#include "psaux.h" #include "timer.h" #include "contty.h" #include "video.h" +#include "audio.h" +#include "pci.h" +#include "vbetest.h" void logohack(void); @@ -32,12 +37,20 @@ void pcboot_main(void) { init_segm(); init_intr(); - kb_init(); + con_init(); + kb_init(); + init_psaux(); + + init_mem(); + + init_pci(); /* initialize the timer */ init_timer(); + audio_init(); + enable_intr(); printf("PCBoot kernel initialized\n"); @@ -47,19 +60,25 @@ void pcboot_main(void) halt_cpu(); while((c = kb_getkey()) >= 0) { - if(c >= KB_F1 && c <= KB_F12) { + switch(c) { + case KB_F1: set_vga_mode(0x13); logohack(); set_vga_mode(3); + break; + + case KB_F2: + vbetest(); + break; } if(isprint(c)) { - printf("key: %d '%c' \n", c, (char)c); + printf("key: %d '%c'\n", c, (char)c); } else { - printf("key: %d \n", c); + printf("key: %d\n", c); } } if((nticks % 250) == 0) { - printf("ticks: %ld\r", nticks); + con_printf(71, 0, "[%ld]", nticks); } } }