[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <54196086.9030204@imgtec.com>
Date: Wed, 17 Sep 2014 11:20:54 +0100
From: Qais Yousef <qais.yousef@...tec.com>
To: Andrew Bresticker <abrestic@...omium.org>,
Jason Cooper <jason@...edaemon.net>
CC: Ralf Baechle <ralf@...ux-mips.org>,
Thomas Gleixner <tglx@...utronix.de>,
Jeffrey Deans <jeffrey.deans@...tec.com>,
Markos Chandras <markos.chandras@...tec.com>,
Paul Burton <paul.burton@...tec.com>,
"Jonas Gorski" <jogo@...nwrt.org>,
John Crispin <blogic@...nwrt.org>,
David Daney <ddaney.cavm@...il.com>,
<linux-mips@...ux-mips.org>, <linux-kernel@...r.kernel.org>
Subject: Re: [PATCH 00/24] MIPS GIC cleanup, part 1
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
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists