On 09/16/2014 12:51 AM, Andrew Bresticker wrote:
The current MIPS GIC driver and the platform code using it are rather ugly and could use a good cleanup before adding device-tree support [0]. This major issues addressed in this series are converting the GIC (and platforms using it) to use IRQ domains and properly mapping interrupts through the GIC instead of using it transparently. For part 2 I plan on: updating the driver to use proper iomem accessors, cleaning up and moving the GIC clocksource driver to drivers/clocksource/, adding DT support, and possibly converting the GIC driver to use generic irqchip. Patches 1-16 are cleanups for the existing GIC driver and prepare platforms using it for the switch to IRQ domains and using the GIC in a non-transparent way. Patches 17-24 convert the GIC driver to use IRQ domains and updates the platforms using it to properly map GIC interrupts instead of using the static routing tables to make the GIC appear transparent. I've tested this series on Malta and, with additional patches, on the DT-enabled Danube platform. Unfortunately I do not have SEAD-3 hardware, so that has only been compile tested. Compile tested on all other affected architectures (ath79, ralink, lantiq).
I boot tested this on sead3 without problems. Cheers, Qais
[0] https://lkml.org/lkml/2014/9/5/542 Andrew Bresticker (24): MIPS: Always use IRQ domains for CPU IRQs MIPS: Rename mips_cpu_intc_init() -> mips_cpu_irq_of_init() MIPS: Provide a generic plat_irq_dispatch MIPS: Set vint handler when mapping CPU interrupts MIPS: i8259: Use IRQ domains MIPS: Add hook to get C0 performance counter interrupt MIPS: smp-cps: Enable all hardware interrupts on secondary CPUs MIPS: Remove gic_{enable,disable}_interrupt() MIPS: sead3: Remove sead3-serial.c MIPS: sead3: Do not overlap CPU/GIC IRQ ranges MIPS: Malta: Move MSC01 interrupt base MIPS: Move MIPS_GIC_IRQ_BASE into platform irq.h MIPS: Move GIC to drivers/irqchip/ irqchip: mips-gic: Implement generic irq_ack/irq_eoi callbacks irqchip: mips-gic: Implement irq_set_type callback irqchip: mips-gic: Fix gic_set_affinity() return value irqchip: mips-gic: Use IRQ domains irqchip: mips-gic: Stop using per-platform mapping tables irqchip: mips-gic: Probe for number of external interrupts irqchip: mips-gic: Use separate edge/level irq_chips irqchip: mips-gic: Support local interrupts irqchip: mips-gic: Remove unnecessary globals MIPS: Malta: Use generic plat_irq_dispatch MIPS: sead3: Use generic plat_irq_dispatch Documentation/devicetree/bindings/mips/cpu_irq.txt | 4 +- arch/mips/Kconfig | 12 +- arch/mips/ath79/irq.c | 1 - arch/mips/ath79/setup.c | 5 + arch/mips/include/asm/gic.h | 82 ++- arch/mips/include/asm/irq_cpu.h | 4 +- arch/mips/include/asm/mach-generic/irq.h | 6 + arch/mips/include/asm/mach-malta/irq.h | 1 - arch/mips/include/asm/mach-sead3/irq.h | 1 - arch/mips/include/asm/mips-boards/maltaint.h | 24 +- arch/mips/include/asm/mips-boards/sead3int.h | 15 +- arch/mips/include/asm/time.h | 1 + arch/mips/kernel/Makefile | 1 - arch/mips/kernel/cevt-gic.c | 14 +- arch/mips/kernel/cevt-r4k.c | 4 +- arch/mips/kernel/i8259.c | 24 +- arch/mips/kernel/irq-gic.c | 402 -------------- arch/mips/kernel/irq_cpu.c | 45 +- arch/mips/kernel/perf_event_mipsxx.c | 23 +- arch/mips/kernel/smp-cps.c | 4 +- arch/mips/kernel/smp-mt.c | 4 +- arch/mips/lantiq/irq.c | 8 +- arch/mips/mti-malta/malta-int.c | 307 ++--------- arch/mips/mti-malta/malta-time.c | 39 +- arch/mips/mti-sead3/sead3-ehci.c | 8 +- arch/mips/mti-sead3/sead3-int.c | 121 +---- arch/mips/mti-sead3/sead3-net.c | 14 +- arch/mips/mti-sead3/sead3-platform.c | 18 +- arch/mips/mti-sead3/sead3-serial.c | 45 -- arch/mips/mti-sead3/sead3-time.c | 35 +- arch/mips/oprofile/op_model_mipsxx.c | 18 +- arch/mips/ralink/irq.c | 10 +- drivers/irqchip/Kconfig | 4 + drivers/irqchip/Makefile | 1 + drivers/irqchip/irq-mips-gic.c | 597 +++++++++++++++++++++ 35 files changed, 867 insertions(+), 1035 deletions(-) delete mode 100644 arch/mips/kernel/irq-gic.c delete mode 100644 arch/mips/mti-sead3/sead3-serial.c create mode 100644 drivers/irqchip/irq-mips-gic.c