Rev 4311 | Rev 4676 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
| Rev 4311 | Rev 4610 | ||
|---|---|---|---|
| Line 34... | Line 34... | ||
| 34 | 34 | ||
| 35 | #include <config.h> |
35 | #include <config.h> |
| 36 | #include <arch.h> |
36 | #include <arch.h> |
| 37 | #include <arch/boot/boot.h> |
37 | #include <arch/boot/boot.h> |
| 38 | #include <genarch/drivers/via-cuda/cuda.h> |
38 | #include <genarch/drivers/via-cuda/cuda.h> |
| - | 39 | #include <genarch/kbrd/kbrd.h> |
|
| 39 | #include <arch/interrupt.h> |
40 | #include <arch/interrupt.h> |
| 40 | #include <genarch/fb/fb.h> |
41 | #include <genarch/fb/fb.h> |
| 41 | #include <genarch/fb/visuals.h> |
42 | #include <genarch/fb/visuals.h> |
| 42 | #include <userspace.h> |
43 | #include <userspace.h> |
| 43 | #include <proc/uarg.h> |
44 | #include <proc/uarg.h> |
| Line 115... | Line 116... | ||
| 115 | #endif |
116 | #endif |
| 116 | 117 | ||
| 117 | /* Initialize IRQ routing */ |
118 | /* Initialize IRQ routing */ |
| 118 | irq_init(IRQ_COUNT, IRQ_COUNT); |
119 | irq_init(IRQ_COUNT, IRQ_COUNT); |
| 119 | 120 | ||
| 120 | if (bootinfo.macio.addr) { |
- | |
| 121 | /* Initialize PIC */ |
- | |
| 122 | cir_t cir; |
- | |
| 123 | void *cir_arg; |
- | |
| 124 | pic_init(bootinfo.macio.addr, PAGE_SIZE, &cir, &cir_arg); |
- | |
| 125 | - | ||
| 126 | #ifdef CONFIG_VIA_CUDA |
- | |
| 127 | uintptr_t pa = bootinfo.macio.addr + 0x16000; |
- | |
| 128 | uintptr_t aligned_addr = ALIGN_DOWN(pa, PAGE_SIZE); |
- | |
| 129 | size_t offset = pa - aligned_addr; |
- | |
| 130 | size_t size = 2 * PAGE_SIZE; |
- | |
| 131 | - | ||
| 132 | cuda_t *cuda = (cuda_t *) |
- | |
| 133 | (hw_map(aligned_addr, offset + size) + offset); |
- | |
| 134 | - | ||
| 135 | /* Initialize I/O controller */ |
- | |
| 136 | cuda_instance_t *cuda_instance = |
- | |
| 137 | cuda_init(cuda, IRQ_CUDA, cir, cir_arg); |
- | |
| 138 | if (cuda_instance) { |
- | |
| 139 | indev_t *sink = stdin_wire(); |
- | |
| 140 | cuda_wire(cuda_instance, sink); |
- | |
| 141 | } |
- | |
| 142 | #endif |
- | |
| 143 | } |
- | |
| 144 | - | ||
| 145 | /* Merge all zones to 1 big zone */ |
121 | /* Merge all zones to 1 big zone */ |
| 146 | zone_merge_all(); |
122 | zone_merge_all(); |
| 147 | } |
123 | } |
| 148 | } |
124 | } |
| 149 | 125 | ||
| Line 155... | Line 131... | ||
| 155 | { |
131 | { |
| 156 | } |
132 | } |
| 157 | 133 | ||
| 158 | void arch_post_smp_init(void) |
134 | void arch_post_smp_init(void) |
| 159 | { |
135 | { |
| - | 136 | if (bootinfo.macio.addr) { |
|
| - | 137 | /* Initialize PIC */ |
|
| - | 138 | cir_t cir; |
|
| - | 139 | void *cir_arg; |
|
| - | 140 | pic_init(bootinfo.macio.addr, PAGE_SIZE, &cir, &cir_arg); |
|
| - | 141 | ||
| - | 142 | #ifdef CONFIG_MAC_KBD |
|
| - | 143 | uintptr_t pa = bootinfo.macio.addr + 0x16000; |
|
| - | 144 | uintptr_t aligned_addr = ALIGN_DOWN(pa, PAGE_SIZE); |
|
| - | 145 | size_t offset = pa - aligned_addr; |
|
| - | 146 | size_t size = 2 * PAGE_SIZE; |
|
| - | 147 | ||
| - | 148 | cuda_t *cuda = (cuda_t *) |
|
| - | 149 | (hw_map(aligned_addr, offset + size) + offset); |
|
| - | 150 | ||
| - | 151 | /* Initialize I/O controller */ |
|
| - | 152 | cuda_instance_t *cuda_instance = |
|
| - | 153 | cuda_init(cuda, IRQ_CUDA, cir, cir_arg); |
|
| - | 154 | if (cuda_instance) { |
|
| - | 155 | kbrd_instance_t *kbrd_instance = kbrd_init(); |
|
| - | 156 | if (kbrd_instance) { |
|
| - | 157 | indev_t *sink = stdin_wire(); |
|
| - | 158 | indev_t *kbrd = kbrd_wire(kbrd_instance, sink); |
|
| - | 159 | cuda_wire(cuda_instance, kbrd); |
|
| - | 160 | pic_enable_interrupt(IRQ_CUDA); |
|
| - | 161 | } |
|
| - | 162 | } |
|
| - | 163 | #endif |
|
| - | 164 | } |
|
| 160 | } |
165 | } |
| 161 | 166 | ||
| 162 | void calibrate_delay_loop(void) |
167 | void calibrate_delay_loop(void) |
| 163 | { |
168 | { |
| 164 | } |
169 | } |