Commit deb9b22b authored by Paul Mundt's avatar Paul Mundt

sh: mach-dreamcast: Convert to sparseirq.

Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent 6eb6f983
...@@ -730,8 +730,7 @@ config GUSA_RB ...@@ -730,8 +730,7 @@ config GUSA_RB
config SPARSE_IRQ config SPARSE_IRQ
def_bool y def_bool y
depends on SUPERH32 && !SH_DREAMCAST && !SH_HIGHLANDER && \ depends on SUPERH32 && !SH_HIGHLANDER && !SH_RTS7751R2D
!SH_RTS7751R2D
help help
This enables support for sparse irqs. This is useful in general This enables support for sparse irqs. This is useful in general
as most CPUs have a fairly sparse array of IRQ vectors, which as most CPUs have a fairly sparse array of IRQ vectors, which
......
...@@ -135,3 +135,30 @@ int systemasic_irq_demux(int irq) ...@@ -135,3 +135,30 @@ int systemasic_irq_demux(int irq)
/* Not reached */ /* Not reached */
return irq; return irq;
} }
void systemasic_irq_init(void)
{
int i, nid = cpu_to_node(boot_cpu_data);
/* Assign all virtual IRQs to the System ASIC int. handler */
for (i = HW_EVENT_IRQ_BASE; i < HW_EVENT_IRQ_MAX; i++) {
unsigned int irq;
irq = create_irq_nr(i, nid);
if (unlikely(irq == 0)) {
pr_err("%s: failed hooking irq %d for systemasic\n",
__func__, i);
return;
}
if (unlikely(irq != i)) {
pr_err("%s: got irq %d but wanted %d, bailing.\n",
__func__, irq, i);
destroy_irq(irq);
return;
}
set_irq_chip_and_handler(i, &systemasic_int,
handle_level_irq);
}
}
...@@ -28,25 +28,8 @@ ...@@ -28,25 +28,8 @@
#include <asm/machvec.h> #include <asm/machvec.h>
#include <mach/sysasic.h> #include <mach/sysasic.h>
extern struct irq_chip systemasic_int;
extern void aica_time_init(void);
extern int systemasic_irq_demux(int);
static void __init dreamcast_setup(char **cmdline_p) static void __init dreamcast_setup(char **cmdline_p)
{ {
int i;
/* Mask all hardware events */
/* XXX */
/* Acknowledge any previous events */
/* XXX */
/* Assign all virtual IRQs to the System ASIC int. handler */
for (i = HW_EVENT_IRQ_BASE; i < HW_EVENT_IRQ_MAX; i++)
set_irq_chip_and_handler(i, &systemasic_int,
handle_level_irq);
board_time_init = aica_time_init; board_time_init = aica_time_init;
} }
...@@ -54,4 +37,5 @@ static struct sh_machine_vector mv_dreamcast __initmv = { ...@@ -54,4 +37,5 @@ static struct sh_machine_vector mv_dreamcast __initmv = {
.mv_name = "Sega Dreamcast", .mv_name = "Sega Dreamcast",
.mv_setup = dreamcast_setup, .mv_setup = dreamcast_setup,
.mv_irq_demux = systemasic_irq_demux, .mv_irq_demux = systemasic_irq_demux,
.mv_init_irq = systemasic_irq_init,
}; };
...@@ -39,5 +39,10 @@ ...@@ -39,5 +39,10 @@
#define HW_EVENT_IRQ_MAX (HW_EVENT_IRQ_BASE + 95) #define HW_EVENT_IRQ_MAX (HW_EVENT_IRQ_BASE + 95)
/* arch/sh/boards/mach-dreamcast/irq.c */
extern int systemasic_irq_demux(int);
extern void systemasic_irq_init(void);
extern void aica_time_init(void);
#endif /* __ASM_SH_DREAMCAST_SYSASIC_H */ #endif /* __ASM_SH_DREAMCAST_SYSASIC_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment