From: Boris Brezillon <boris.brezillon@free-electrons.com>
To: Milo Kim <milo.kim@ti.com>
Cc: <tglx@linutronix.de>, <jason@lakedaemon.net>,
<marc.zyngier@arm.com>, <alexandre.belloni@free-electrons.com>,
<ludovic.desroches@atmel.com>, <nicolas.ferre@atmel.com>,
<linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 00/19] irqchip: atmel-aic: make unified AIC driver
Date: Mon, 4 Jan 2016 10:02:38 +0100 [thread overview]
Message-ID: <20160104100238.2b40f736@bbrezillon> (raw)
In-Reply-To: <1451881723-2478-1-git-send-email-milo.kim@ti.com>
Hi Milo,
On Mon, 4 Jan 2016 13:28:24 +0900
Milo Kim <milo.kim@ti.com> wrote:
> This patch-set provides unified Atmel AIC (Advanced Interrupt Controller)
> driver. Currently, there are two AIC drivers, AIC and AIC5.
> Each driver consists of chip specific part (irq-atmel-aic.o or
> irq-atmel-aic5.o) and shared code (irq-atmel-aic-common.o).
> But consolidated AIC driver is just one file driver which supports both
> IRQ chip systems.
Sorry, but what's the real motivation behind this rework?
>
> How to handle two IRQ chips in one driver
> -----------------------------------------
> Structure aic_reg_offset is used for device configuration.
> AIC5 IRQ chip uses SSR (Source Select Register) to select IRQ number.
> On the other hand, AIC IRQ chip has simple register access.
> To support both IRQ chips, aic_is_ssr_used() helper is used.
>
> Patches
> -------
> 1 ~ 5: fix IRQ priority issue, clean up RTC/RTT fixup code and etc.
As explained in my review, those irq fixup are essential, and cannot
remove them.
> 6 ~ 19: create unified IRQ chip operation with aic_reg_offset data.
I started to review those patches, but honestly I don't see the point of
this rework, since you're trying to merge drivers for 2 IPs that are
completely different from a functional POV (except for a few tiny things
like priority or irq type definition).
Before reviewing the remaining patches, I'd like to know more about your
real motivations for pushing those changes?
>
> Target boards
> -------------
> Tested with two boards.
> * Arietta G25 (SoC: AT91SAM9G25)
> * Xplained board (SoC: SAMA5D3)
>
> Number of driver files
> ----------------------
> AIC: 3 (irq-atmel-aic.c, irq-atmel-aic-common.c and h)
> AIC5: 3 (irq-atmel-aic5.c, irq-atmel-aic-common.c and h)
> Consolidated AIC: 1 (irq-aic.c)
>
> Code size
> ---------
> AIC (irq-atmel-aic.o and irq-atmel-aic-common.o)
> text data bss dec hex filename
> 5137 196 4 5337 14d9 drivers/irqchip/built-in.o
>
> AIC5 (irq-atmel-aic5.o and irq-atmel-aic-common.o)
> text data bss dec hex filename
> 5548 196 4 5748 1674 drivers/irqchip/built-in.o
>
> Consolidated AIC (irq-aic.o)
> text data bss dec hex filename
> 4841 196 8 5045 13b5 drivers/irqchip/built-in.o
>
> Lines of code
> -------------
> AIC: 597
> AIC5: 688
> Consolidated AIC: 609
Please, redo the same thing, but after keeping the IRQ fixup stuff, and
I'm pretty sure the text section of the AIC/AIC5 and the consolidated
version will be much closer.
Not to mention that you're adding a bunch of if () statements in the
critical IRQ path, which is never a good think for latency concern.
Best Regards,
Boris
>
> Milo Kim (19):
> irqchip: atmel-aic: fix wrong bit operation for IRQ priority
> irqchip: atmel-aic: clean up RTC interrupt code
> irqchip: atmel-aic: clean up RTT interrupt code
> irqchip: atmel-aic: replace magic numbers with named constant
> irqchip: atmel-aic: use simple constant to get number of interrupts
> per chip
> irqchip: atmel-aic: introduce register data structure
> irqchip: atmel-aic: make common IRQ domain translate function
> irqchip: atmel-aic: add common mask and unmask functions
> irqchip: atmel-aic: add common retrigger function
> irqchip: atmel-aic: add common set_type function
> irqchip: atmel-aic: add common PM IRQ chip operation
> irqchip: atmel-aic: use EOI register data in aic_reg_data
> irqchip: atmel-aic: clean up irq_chip_generic
> irqchip: atmel-aic: add common HW init function
> irqchip: atmel-aic: add common interrupt handler
> irqchip: atmel-aic: get total number of IRQs from device node
> irqchip: atmel-aic: use unified IRQ chip initialization function
> irqchip: atmel-aic: use unified AIC driver
> irqchip: atmel-aic: rename AIC driver and fix Kconfig
>
> arch/arm/mach-at91/Kconfig | 2 +-
> drivers/irqchip/Kconfig | 7 -
> drivers/irqchip/Makefile | 3 +-
> drivers/irqchip/irq-aic.c | 609 +++++++++++++++++++++++++++++++++
> drivers/irqchip/irq-atmel-aic-common.c | 280 ---------------
> drivers/irqchip/irq-atmel-aic-common.h | 41 ---
> drivers/irqchip/irq-atmel-aic.c | 276 ---------------
> drivers/irqchip/irq-atmel-aic5.c | 367 --------------------
> 8 files changed, 611 insertions(+), 974 deletions(-)
> create mode 100644 drivers/irqchip/irq-aic.c
> delete mode 100644 drivers/irqchip/irq-atmel-aic-common.c
> delete mode 100644 drivers/irqchip/irq-atmel-aic-common.h
> delete mode 100644 drivers/irqchip/irq-atmel-aic.c
> delete mode 100644 drivers/irqchip/irq-atmel-aic5.c
>
--
Boris Brezillon, Free Electrons
Embedded Linux and Kernel engineering
http://free-electrons.com
next prev parent reply other threads:[~2016-01-04 9:02 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-01-04 4:28 [PATCH 00/19] irqchip: atmel-aic: make unified AIC driver Milo Kim
2016-01-04 4:28 ` [PATCH 01/19] irqchip: atmel-aic: fix wrong bit operation for IRQ priority Milo Kim
2016-01-04 8:11 ` Boris Brezillon
2016-01-04 4:28 ` [PATCH 02/19] irqchip: atmel-aic: clean up RTC interrupt code Milo Kim
2016-01-04 8:16 ` Boris Brezillon
2016-01-04 4:28 ` [PATCH 03/19] irqchip: atmel-aic: clean up RTT " Milo Kim
2016-01-04 8:17 ` Boris Brezillon
2016-01-04 4:28 ` [PATCH 04/19] irqchip: atmel-aic: replace magic numbers with named constant Milo Kim
2016-01-04 8:29 ` Boris Brezillon
2016-01-04 4:28 ` [PATCH 05/19] irqchip: atmel-aic: use simple constant to get number of interrupts per chip Milo Kim
2016-01-04 8:33 ` Boris Brezillon
2016-01-04 4:28 ` [PATCH 06/19] irqchip: atmel-aic: introduce register data structure Milo Kim
2016-01-04 8:53 ` Boris Brezillon
2016-01-06 8:30 ` Milo Kim
2016-01-04 4:28 ` [PATCH 07/19] irqchip: atmel-aic: make common IRQ domain translate function Milo Kim
2016-01-04 4:28 ` [PATCH 08/19] irqchip: atmel-aic: add common mask and unmask functions Milo Kim
2016-01-04 8:48 ` Boris Brezillon
2016-01-04 4:28 ` [PATCH 09/19] irqchip: atmel-aic: add common retrigger function Milo Kim
2016-01-04 4:28 ` [PATCH 10/19] irqchip: atmel-aic: add common set_type function Milo Kim
2016-01-04 4:28 ` [PATCH 11/19] irqchip: atmel-aic: add common PM IRQ chip operation Milo Kim
2016-01-04 4:28 ` [PATCH 12/19] irqchip: atmel-aic: use EOI register data in aic_reg_data Milo Kim
2016-01-04 4:28 ` [PATCH 13/19] irqchip: atmel-aic: clean up irq_chip_generic Milo Kim
2016-01-04 4:28 ` [PATCH 14/19] irqchip: atmel-aic: add common HW init function Milo Kim
2016-01-04 4:28 ` [PATCH 15/19] irqchip: atmel-aic: add common interrupt handler Milo Kim
2016-01-04 4:28 ` [PATCH 16/19] irqchip: atmel-aic: get total number of IRQs from device node Milo Kim
2016-01-04 4:28 ` [PATCH 17/19] irqchip: atmel-aic: use unified IRQ chip initialization function Milo Kim
2016-01-04 4:28 ` [PATCH 18/19] irqchip: atmel-aic: use unified AIC driver Milo Kim
2016-01-04 4:28 ` [PATCH 19/19] irqchip: atmel-aic: rename AIC driver and fix Kconfig Milo Kim
2016-01-04 9:02 ` Boris Brezillon [this message]
2016-01-04 9:37 ` [PATCH 00/19] irqchip: atmel-aic: make unified AIC driver Nicolas Ferre
2016-01-06 7:55 ` Milo Kim
2016-01-06 7:48 ` Milo Kim
2016-01-06 9:07 ` Boris Brezillon
2016-01-06 14:49 ` Jason Cooper
2016-01-07 7:48 ` Milo Kim
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20160104100238.2b40f736@bbrezillon \
--to=boris.brezillon@free-electrons.com \
--cc=alexandre.belloni@free-electrons.com \
--cc=jason@lakedaemon.net \
--cc=linux-kernel@vger.kernel.org \
--cc=ludovic.desroches@atmel.com \
--cc=marc.zyngier@arm.com \
--cc=milo.kim@ti.com \
--cc=nicolas.ferre@atmel.com \
--cc=tglx@linutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.