aboutsummaryrefslogtreecommitdiffstats
path: root/debian/patches/bugfix/m68k/mac68k-revert-remaining-irq-damage.diff
diff options
context:
space:
mode:
Diffstat (limited to 'debian/patches/bugfix/m68k/mac68k-revert-remaining-irq-damage.diff')
-rw-r--r--debian/patches/bugfix/m68k/mac68k-revert-remaining-irq-damage.diff80
1 files changed, 80 insertions, 0 deletions
diff --git a/debian/patches/bugfix/m68k/mac68k-revert-remaining-irq-damage.diff b/debian/patches/bugfix/m68k/mac68k-revert-remaining-irq-damage.diff
new file mode 100644
index 000000000000..bfc12bad9044
--- /dev/null
+++ b/debian/patches/bugfix/m68k/mac68k-revert-remaining-irq-damage.diff
@@ -0,0 +1,80 @@
+Subject: [PATCH 5/13] m68k: reverse Mac IRQ damage
+
+From: Finn Thain <fthain@telegraphics.com.au>
+
+Reverse the last of a monumental brown-paper-bag commit that went into the 2.3
+kernel.
+
+Signed-off-by: Finn Thain <fthain@telegraphics.com.au>
+Signed-off-by: Geert Uytterhoeven <geert@linux-m68k.org>
+---
+ arch/m68k/mac/baboon.c | 2 +-
+ arch/m68k/mac/oss.c | 6 +++---
+ arch/m68k/mac/psc.c | 2 +-
+ arch/m68k/mac/via.c | 2 +-
+ 4 files changed, 6 insertions(+), 6 deletions(-)
+
+--- linux-m68k-2.6.21.orig/arch/m68k/mac/baboon.c
++++ linux-m68k-2.6.21/arch/m68k/mac/baboon.c
+@@ -81,9 +81,9 @@ irqreturn_t baboon_irq(int irq, void *de
+ for (i = 0, irq_bit = 1 ; i < 3 ; i++, irq_bit <<= 1) {
+ if (events & irq_bit/* & baboon_active*/) {
+ baboon_active &= ~irq_bit;
++ baboon->mb_ifr &= ~irq_bit;
+ m68k_handle_int(IRQ_BABOON_0 + i);
+ baboon_active |= irq_bit;
+- baboon->mb_ifr &= ~irq_bit;
+ }
+ }
+ #if 0
+--- linux-m68k-2.6.21.orig/arch/m68k/mac/oss.c
++++ linux-m68k-2.6.21/arch/m68k/mac/oss.c
+@@ -109,12 +109,12 @@ irqreturn_t oss_irq(int irq, void *dev_i
+ /* FIXME: how do you clear a pending IRQ? */
+
+ if (events & OSS_IP_SOUND) {
+- /* FIXME: call sound handler */
+ oss->irq_pending &= ~OSS_IP_SOUND;
++ /* FIXME: call sound handler */
+ } else if (events & OSS_IP_SCSI) {
+ oss->irq_level[OSS_SCSI] = OSS_IRQLEV_DISABLED;
+- m68k_handle_int(IRQ_MAC_SCSI);
+ oss->irq_pending &= ~OSS_IP_SCSI;
++ m68k_handle_int(IRQ_MAC_SCSI);
+ oss->irq_level[OSS_SCSI] = OSS_IRQLEV_SCSI;
+ } else {
+ /* FIXME: error check here? */
+@@ -146,8 +146,8 @@ irqreturn_t oss_nubus_irq(int irq, void
+ for (i = 0, irq_bit = 1 ; i < 6 ; i++, irq_bit <<= 1) {
+ if (events & irq_bit) {
+ oss->irq_level[i] = OSS_IRQLEV_DISABLED;
+- m68k_handle_int(NUBUS_SOURCE_BASE + i);
+ oss->irq_pending &= ~irq_bit;
++ m68k_handle_int(NUBUS_SOURCE_BASE + i);
+ oss->irq_level[i] = OSS_IRQLEV_NUBUS;
+ }
+ }
+--- linux-m68k-2.6.21.orig/arch/m68k/mac/psc.c
++++ linux-m68k-2.6.21/arch/m68k/mac/psc.c
+@@ -149,8 +149,8 @@ irqreturn_t psc_irq(int irq, void *dev_i
+ for (i = 0, irq_bit = 1 ; i < 4 ; i++, irq_bit <<= 1) {
+ if (events & irq_bit) {
+ psc_write_byte(pIER, irq_bit);
+- m68k_handle_int(base_irq + i);
+ psc_write_byte(pIFR, irq_bit);
++ m68k_handle_int(base_irq + i);
+ psc_write_byte(pIER, irq_bit | 0x80);
+ }
+ }
+--- linux-m68k-2.6.21.orig/arch/m68k/mac/via.c
++++ linux-m68k-2.6.21/arch/m68k/mac/via.c
+@@ -430,8 +430,8 @@ irqreturn_t via1_irq(int irq, void *dev_
+ for (i = 0, irq_bit = 1 ; i < 7 ; i++, irq_bit <<= 1)
+ if (events & irq_bit) {
+ via1[vIER] = irq_bit;
+- m68k_handle_int(VIA1_SOURCE_BASE + i);
+ via1[vIFR] = irq_bit;
++ m68k_handle_int(VIA1_SOURCE_BASE + i);
+ via1[vIER] = irq_bit | 0x80;
+ }
+