#include "video_low.h"
#include "input.h"
#include "console.h"
+#include "ohci.h"
+#include "irq.h"
#define MINIMUM_MINI_VERSION 0x00010001
dsp_reset();
// clear interrupt mask
- write32(0x0c003004, 0);
+ write32(BW_PI_IRQMASK, 0);
ipc_initialize();
ipc_slowping();
gecko_init();
input_init();
init_fb(vmode);
+ ohci_init();
VIDEO_Init(vmode);
VIDEO_SetFrameBuffer(get_xfb());
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;
}