Commit 9350cd01 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'sh-for-v6.5-tag2' of git://git.kernel.org/pub/scm/linux/kernel/git/glaubitz/sh-linux

Pull sh fixes from John Paul Adrian Glaubitz:
 "The sh updates introduced multiple regressions.

  In particular, the change a8ac2961 ("sh: Avoid using IRQ0 on SH3
  and SH4") causes several boards to hang during boot due to incorrect
  IRQ numbers.

  Geert Uytterhoeven has contributed patches that handle the virq offset
  in the IRQ code for the dreamcast, highlander and r2d boards while
  Artur Rojek has contributed a patch which handles the virq offset for
  the hd64461 companion chip"

* tag 'sh-for-v6.5-tag2' of git://git.kernel.org/pub/scm/linux/kernel/git/glaubitz/sh-linux:
  sh: hd64461: Handle virq offset for offchip IRQ base and HD64461 IRQ
  sh: mach-dreamcast: Handle virq offset in cascaded IRQ demux
  sh: mach-highlander: Handle virq offset in cascaded IRL demux
  sh: mach-r2d: Handle virq offset in cascaded IRL demux
parents 0099852f 7c28a35e
...@@ -108,13 +108,13 @@ int systemasic_irq_demux(int irq) ...@@ -108,13 +108,13 @@ int systemasic_irq_demux(int irq)
__u32 j, bit; __u32 j, bit;
switch (irq) { switch (irq) {
case 13: case 13 + 16:
level = 0; level = 0;
break; break;
case 11: case 11 + 16:
level = 1; level = 1;
break; break;
case 9: case 9 + 16:
level = 2; level = 2;
break; break;
default: default:
......
...@@ -389,10 +389,10 @@ static unsigned char irl2irq[HL_NR_IRL]; ...@@ -389,10 +389,10 @@ static unsigned char irl2irq[HL_NR_IRL];
static int highlander_irq_demux(int irq) static int highlander_irq_demux(int irq)
{ {
if (irq >= HL_NR_IRL || irq < 0 || !irl2irq[irq]) if (irq >= HL_NR_IRL + 16 || irq < 16 || !irl2irq[irq - 16])
return irq; return irq;
return irl2irq[irq]; return irl2irq[irq - 16];
} }
static void __init highlander_init_irq(void) static void __init highlander_init_irq(void)
......
...@@ -117,10 +117,10 @@ static unsigned char irl2irq[R2D_NR_IRL]; ...@@ -117,10 +117,10 @@ static unsigned char irl2irq[R2D_NR_IRL];
int rts7751r2d_irq_demux(int irq) int rts7751r2d_irq_demux(int irq)
{ {
if (irq >= R2D_NR_IRL || irq < 0 || !irl2irq[irq]) if (irq >= R2D_NR_IRL + 16 || irq < 16 || !irl2irq[irq - 16])
return irq; return irq;
return irl2irq[irq]; return irl2irq[irq - 16];
} }
/* /*
......
...@@ -29,9 +29,9 @@ endchoice ...@@ -29,9 +29,9 @@ endchoice
config HD64461_IRQ config HD64461_IRQ
int "HD64461 IRQ" int "HD64461 IRQ"
depends on HD64461 depends on HD64461
default "36" default "52"
help help
The default setting of the HD64461 IRQ is 36. The default setting of the HD64461 IRQ is 52.
Do not change this unless you know what you are doing. Do not change this unless you know what you are doing.
......
...@@ -229,7 +229,7 @@ ...@@ -229,7 +229,7 @@
#define HD64461_NIMR HD64461_IO_OFFSET(0x5002) #define HD64461_NIMR HD64461_IO_OFFSET(0x5002)
#define HD64461_IRQBASE OFFCHIP_IRQ_BASE #define HD64461_IRQBASE OFFCHIP_IRQ_BASE
#define OFFCHIP_IRQ_BASE 64 #define OFFCHIP_IRQ_BASE (64 + 16)
#define HD64461_IRQ_NUM 16 #define HD64461_IRQ_NUM 16
#define HD64461_IRQ_UART (HD64461_IRQBASE+5) #define HD64461_IRQ_UART (HD64461_IRQBASE+5)
......
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