implemented simple irq handler, added irq.h
[ppcskel.git] / main.c
diff --git a/main.c b/main.c
index 4303241a7430baad434e3d21f297ed5b464043ab..ca0b2eaedb6a58ac26a7d75a89063cd940f591bf 100644 (file)
--- a/main.c
+++ b/main.c
@@ -24,6 +24,8 @@ Copyright (C) 2009              John Kelley <wiidev@kelley.ca>
 #include "video_low.h"
 #include "input.h"
 #include "console.h"
+#include "ohci.h"
+#include "irq.h"
 
 #define MINIMUM_MINI_VERSION 0x00010001
 
@@ -83,7 +85,7 @@ int main(void)
        dsp_reset();
 
        // clear interrupt mask
-       write32(0x0c003004, 0);
+       write32(BW_PI_IRQMASK, 0);
 
        ipc_initialize();
        ipc_slowping();
@@ -91,6 +93,7 @@ int main(void)
        gecko_init();
     input_init();
        init_fb(vmode);
+       ohci_init();
 
        VIDEO_Init(vmode);
        VIDEO_SetFrameBuffer(get_xfb());
@@ -115,20 +118,20 @@ int main(void)
 
        printf("bye, world!\n");
 
-       // enable RESET interrupt 
-       write32(0x0c003004, 1<<1);
-#define _CPU_ISR_Enable() \
-       { register u32 _val = 0; \
-         __asm__ __volatile__ ( \
-               "mfmsr %0\n" \
-               "ori %0,%0,0x8000\n" \
-               "mtmsr %0" \
-               : "=&r" ((_val)) : "0" ((_val)) \
-         ); \
-       }
+       // enable OHCI0 interrupt on hollywood-pic
+       write32(HW_PPCIRQFLAG, ~0);
+       write32(HW_PPCIRQMASK, 1<<5);
+       // enable RESET and PIC (#14) interrupts on processor interface
+       write32(BW_PI_IRQFLAG, ~0);
+       write32(BW_PI_IRQMASK, (1<<1) | (1<<14));
        _CPU_ISR_Enable()
 
-       while(1) {}
+       while(1) {
+               // just to get sure we are still in this loop
+               _CPU_ISR_Enable() // don't know why this is needed...
+               udelay(100000);
+               printf("x");
+       }
 
        return 0;
 }