To: linus, akpm Cc: lkml Subject: [PATCH] m68k/Atari: Interrupt updates Misc Atari fixes: - initialize correct number of atari irqs - silence vbl interrupt until it's used by atafb - use mdelay() to read clock if necessary Signed-Off-By: Roman Zippel Signed-Off-By: Geert Uytterhoeven --- atari/ataints.c | 9 +++++++-- atari/time.c | 9 +++++++-- kernel/ints.c | 1 + 3 files changed, 15 insertions(+), 4 deletions(-) --- linux/arch/m68k/atari/ataints.c 2006/01/28 21:33:28 1.14 +++ linux/arch/m68k/atari/ataints.c 2006/09/03 14:52:16 1.15 @@ -332,6 +332,9 @@ static void atari_shutdown_irq(unsigned atari_disable_irq(irq); atari_turnoff_irq(irq); m68k_irq_shutdown(irq); + + if (irq == IRQ_AUTO_4) + vectors[VEC_INT4] = falcon_hblhandler; } static struct irq_controller atari_irq_controller = { @@ -356,7 +359,7 @@ static struct irq_controller atari_irq_c void __init atari_init_IRQ(void) { - m68k_setup_user_interrupt(VEC_USER, 192, NULL); + m68k_setup_user_interrupt(VEC_USER, NUM_ATARI_SOURCES - IRQ_USER, NULL); m68k_setup_irq_controller(&atari_irq_controller, 1, NUM_ATARI_SOURCES - 1); /* Initialize the MFP(s) */ @@ -403,8 +406,10 @@ void __init atari_init_IRQ(void) * gets overruns) */ - if (!MACH_IS_HADES) + if (!MACH_IS_HADES) { vectors[VEC_INT2] = falcon_hblhandler; + vectors[VEC_INT4] = falcon_hblhandler; + } } if (ATARIHW_PRESENT(PCM_8BIT) && ATARIHW_PRESENT(MICROWIRE)) { --- linux/arch/m68k/atari/time.c 2006/01/14 23:07:09 1.1.1.7 +++ linux/arch/m68k/atari/time.c 2006/09/03 14:52:16 1.9 @@ -16,6 +16,7 @@ #include #include #include +#include #include @@ -212,8 +213,12 @@ int atari_tt_hwclk( int op, struct rtc_t * additionally the RTC_SET bit is set to prevent an update cycle. */ - while( RTC_READ(RTC_FREQ_SELECT) & RTC_UIP ) - schedule_timeout_interruptible(HWCLK_POLL_INTERVAL); + while( RTC_READ(RTC_FREQ_SELECT) & RTC_UIP ) { + if (in_atomic() || irqs_disabled()) + mdelay(1); + else + schedule_timeout_interruptible(HWCLK_POLL_INTERVAL); + } local_irq_save(flags); RTC_WRITE( RTC_CONTROL, ctrl | RTC_SET ); --- linux/arch/m68k/kernel/ints.c 2006/01/31 00:57:35 1.10 +++ linux/arch/m68k/kernel/ints.c 2006/09/03 14:52:17 1.11 @@ -132,6 +132,7 @@ void __init m68k_setup_user_interrupt(un { int i; + BUG_ON(IRQ_USER + cnt >= NR_IRQS); m68k_first_user_vec = vec; for (i = 0; i < cnt; i++) irq_controller[IRQ_USER + i] = &user_irq_controller;