提交 a1eb1cdf 编写于 作者: F Finn Thain 提交者: Geert Uytterhoeven

m68k/mac: Fix apparent race condition in Baboon interrupt dispatch

The algorithm used in baboon_irq() appears to be subject to a race
condition: an IRQ flag could be lost if asserted between the MOV
instructions from and to the interrupt flag register. However,
testing shows that the write to the flag register has no effect.
Rewrite this loop to remove the apparent race condition.

No-one seems to know how to clear Baboon IRQ flags, or whether
that's even possible, so add a comment about this.
Tested-by: NStan Johnson <userm57@yahoo.com>
Signed-off-by: NFinn Thain <fthain@telegraphics.com.au>
Signed-off-by: NGeert Uytterhoeven <geert@linux-m68k.org>
上级 e5f0d2e2
...@@ -18,10 +18,6 @@ ...@@ -18,10 +18,6 @@
int baboon_present; int baboon_present;
static volatile struct baboon *baboon; static volatile struct baboon *baboon;
#if 0
extern int macide_ack_intr(struct ata_channel *);
#endif
/* /*
* Baboon initialization. * Baboon initialization.
*/ */
...@@ -41,33 +37,26 @@ void __init baboon_init(void) ...@@ -41,33 +37,26 @@ void __init baboon_init(void)
} }
/* /*
* Baboon interrupt handler. This works a lot like a VIA. * Baboon interrupt handler.
* XXX how do you clear a pending IRQ? is it even necessary?
*/ */
static void baboon_irq(struct irq_desc *desc) static void baboon_irq(struct irq_desc *desc)
{ {
int irq_bit, irq_num; short events, irq_bit;
unsigned char events; int irq_num;
events = baboon->mb_ifr & 0x07; events = baboon->mb_ifr & 0x07;
if (!events)
return;
irq_num = IRQ_BABOON_0; irq_num = IRQ_BABOON_0;
irq_bit = 1; irq_bit = 1;
do { do {
if (events & irq_bit) { if (events & irq_bit) {
baboon->mb_ifr &= ~irq_bit; events &= ~irq_bit;
generic_handle_irq(irq_num); generic_handle_irq(irq_num);
} }
++irq_num;
irq_bit <<= 1; irq_bit <<= 1;
irq_num++; } while (events);
} while(events >= irq_bit);
#if 0
if (baboon->mb_ifr & 0x02) macide_ack_intr(NULL);
/* for now we need to smash all interrupts */
baboon->mb_ifr &= ~events;
#endif
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册