* [PATCH] irqdomain: factorise irq_domain_xlate_onetwocell()
@ 2016-08-01 14:27 Sebastian Frias
2016-08-01 14:57 ` [PATCH v2] " Sebastian Frias
0 siblings, 1 reply; 5+ messages in thread
From: Sebastian Frias @ 2016-08-01 14:27 UTC (permalink / raw)
To: Grant Likely, Marc Zyngier, Thomas Gleixner, Jason Cooper; +Cc: LKML, Mason
Commit 16b2e6e2f31d ("irq_domain: Create common xlate functions that device
drivers can use") introduced three similar functions:
irq_domain_xlate_onecell()
irq_domain_xlate_twocell()
irq_domain_xlate_onetwocell()
yet the last one, irq_domain_xlate_onetwocell(), can be factored to use the
two previous ones to avoid code duplication.
Fixes: 16b2e6e2f31d ("irq_domain: Create common xlate functions that device
drivers can use")
Signed-off-by: Sebastian Frias <sf84@laposte.net>
---
NOTE: the factored code is not strictly the same in the sense that
16b2e6e2f31d returns "intspec[1]" as 'out_type', while this patch would
make it return "intspec[1] & IRQ_TYPE_SENSE_MASK".
Feel free to comment on that matter.
---
kernel/irq/irqdomain.c | 17 ++++++++++++++---
1 file changed, 14 insertions(+), 3 deletions(-)
diff --git a/kernel/irq/irqdomain.c b/kernel/irq/irqdomain.c
index bee8b02..ea2df0e 100644
--- a/kernel/irq/irqdomain.c
+++ b/kernel/irq/irqdomain.c
@@ -839,9 +839,20 @@ int irq_domain_xlate_onetwocell(struct irq_domain *d,
{
if (WARN_ON(intsize < 1))
return -EINVAL;
- *out_hwirq = intspec[0];
- *out_type = (intsize > 1) ? intspec[1] : IRQ_TYPE_NONE;
- return 0;
+ if (intsize == 1)
+ return irq_domain_xlate_onecell(d,
+ ctrlr,
+ intspec,
+ intsize,
+ out_hwirq,
+ out_type);
+ else
+ return irq_domain_xlate_twocell(d,
+ ctrlr,
+ intspec,
+ intsize,
+ out_hwirq,
+ out_type);
}
EXPORT_SYMBOL_GPL(irq_domain_xlate_onetwocell);
--
1.7.11.2
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [PATCH v2] irqdomain: factorise irq_domain_xlate_onetwocell()
2016-08-01 14:27 [PATCH] irqdomain: factorise irq_domain_xlate_onetwocell() Sebastian Frias
@ 2016-08-01 14:57 ` Sebastian Frias
2016-08-01 17:07 ` Thomas Gleixner
0 siblings, 1 reply; 5+ messages in thread
From: Sebastian Frias @ 2016-08-01 14:57 UTC (permalink / raw)
To: Grant Likely, Marc Zyngier, Thomas Gleixner, Jason Cooper; +Cc: LKML, Mason
Commit 16b2e6e2f31d ("irq_domain: Create common xlate functions that device
drivers can use") introduced three similar functions:
irq_domain_xlate_onecell()
irq_domain_xlate_twocell()
irq_domain_xlate_onetwocell()
yet the last one, irq_domain_xlate_onetwocell(), can be factored to use the
two previous ones to avoid code duplication.
Fixes: 16b2e6e2f31d ("irq_domain: Create common xlate functions that device
drivers can use")
Signed-off-by: Sebastian Frias <sf84@laposte.net>
---
NOTE: the factored code is not strictly the same in the sense that
16b2e6e2f31d returns "intspec[1]" as 'out_type', while this patch would
make it return "intspec[1] & IRQ_TYPE_SENSE_MASK".
Feel free to comment on that matter.
---
kernel/irq/irqdomain.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/kernel/irq/irqdomain.c b/kernel/irq/irqdomain.c
index bee8b02..125a28c 100644
--- a/kernel/irq/irqdomain.c
+++ b/kernel/irq/irqdomain.c
@@ -839,9 +839,12 @@ int irq_domain_xlate_onetwocell(struct irq_domain *d,
{
if (WARN_ON(intsize < 1))
return -EINVAL;
- *out_hwirq = intspec[0];
- *out_type = (intsize > 1) ? intspec[1] : IRQ_TYPE_NONE;
- return 0;
+ if (intsize == 1)
+ return irq_domain_xlate_onecell(d, ctrlr, intspec, intsize,
+ out_hwirq, out_type);
+ else
+ return irq_domain_xlate_twocell(d, ctrlr, intspec, intsize,
+ out_hwirq, out_type);
}
EXPORT_SYMBOL_GPL(irq_domain_xlate_onetwocell);
--
1.7.11.2
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH v2] irqdomain: factorise irq_domain_xlate_onetwocell()
2016-08-01 14:57 ` [PATCH v2] " Sebastian Frias
@ 2016-08-01 17:07 ` Thomas Gleixner
2016-08-02 8:31 ` Sebastian Frias
0 siblings, 1 reply; 5+ messages in thread
From: Thomas Gleixner @ 2016-08-01 17:07 UTC (permalink / raw)
To: Sebastian Frias; +Cc: Grant Likely, Marc Zyngier, Jason Cooper, LKML, Mason
On Mon, 1 Aug 2016, Sebastian Frias wrote:
> Commit 16b2e6e2f31d ("irq_domain: Create common xlate functions that device
> drivers can use") introduced three similar functions:
>
> irq_domain_xlate_onecell()
> irq_domain_xlate_twocell()
> irq_domain_xlate_onetwocell()
>
> yet the last one, irq_domain_xlate_onetwocell(), can be factored to use the
> two previous ones to avoid code duplication.
>
> Fixes: 16b2e6e2f31d ("irq_domain: Create common xlate functions that device
> drivers can use")
That does not fix anything. It optimizes code. We use the "Fixes" tag only
when the existing code is buggy.
> Signed-off-by: Sebastian Frias <sf84@laposte.net>
> ---
>
> NOTE: the factored code is not strictly the same in the sense that
> 16b2e6e2f31d returns "intspec[1]" as 'out_type', while this patch would
> make it return "intspec[1] & IRQ_TYPE_SENSE_MASK".
So the proper way to do that is to split this into two patches:
#1 Change the existing code to do the masking and explain why it is correct.
#2 Refactor the code and get rid of the duplicated implementation.
> Feel free to comment on that matter.
>
> ---
> kernel/irq/irqdomain.c | 9 ++++++---
> 1 file changed, 6 insertions(+), 3 deletions(-)
>
> diff --git a/kernel/irq/irqdomain.c b/kernel/irq/irqdomain.c
> index bee8b02..125a28c 100644
> --- a/kernel/irq/irqdomain.c
> +++ b/kernel/irq/irqdomain.c
> @@ -839,9 +839,12 @@ int irq_domain_xlate_onetwocell(struct irq_domain *d,
> {
> if (WARN_ON(intsize < 1))
> return -EINVAL;
> - *out_hwirq = intspec[0];
> - *out_type = (intsize > 1) ? intspec[1] : IRQ_TYPE_NONE;
> - return 0;
> + if (intsize == 1)
> + return irq_domain_xlate_onecell(d, ctrlr, intspec, intsize,
> + out_hwirq, out_type);
> + else
> + return irq_domain_xlate_twocell(d, ctrlr, intspec, intsize,
> + out_hwirq, out_type);
So I really wonder how much of a saving that change is. I wouldn't be
surprised if it would create worse code on some architectures.
Thanks,
tglx
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH v2] irqdomain: factorise irq_domain_xlate_onetwocell()
2016-08-01 17:07 ` Thomas Gleixner
@ 2016-08-02 8:31 ` Sebastian Frias
2016-08-02 9:07 ` Sebastian Frias
0 siblings, 1 reply; 5+ messages in thread
From: Sebastian Frias @ 2016-08-02 8:31 UTC (permalink / raw)
To: Thomas Gleixner; +Cc: Grant Likely, Marc Zyngier, Jason Cooper, LKML, Mason
Hi Thomas,
On 08/01/2016 07:07 PM, Thomas Gleixner wrote:
> On Mon, 1 Aug 2016, Sebastian Frias wrote:
>> Commit 16b2e6e2f31d ("irq_domain: Create common xlate functions that device
>> drivers can use") introduced three similar functions:
>>
>> irq_domain_xlate_onecell()
>> irq_domain_xlate_twocell()
>> irq_domain_xlate_onetwocell()
>>
>> yet the last one, irq_domain_xlate_onetwocell(), can be factored to use the
>> two previous ones to avoid code duplication.
>>
>> Fixes: 16b2e6e2f31d ("irq_domain: Create common xlate functions that device
>> drivers can use")
>
> That does not fix anything. It optimizes code. We use the "Fixes" tag only
> when the existing code is buggy.
Ok, I will remove that.
>
>> Signed-off-by: Sebastian Frias <sf84@laposte.net>
>> ---
>>
>> NOTE: the factored code is not strictly the same in the sense that
>> 16b2e6e2f31d returns "intspec[1]" as 'out_type', while this patch would
>> make it return "intspec[1] & IRQ_TYPE_SENSE_MASK".
>
> So the proper way to do that is to split this into two patches:
>
> #1 Change the existing code to do the masking and explain why it is correct.
>
> #2 Refactor the code and get rid of the duplicated implementation.
Ok, I can do two patches.
>
>
>> Feel free to comment on that matter.
>>
>> ---
>> kernel/irq/irqdomain.c | 9 ++++++---
>> 1 file changed, 6 insertions(+), 3 deletions(-)
>>
>> diff --git a/kernel/irq/irqdomain.c b/kernel/irq/irqdomain.c
>> index bee8b02..125a28c 100644
>> --- a/kernel/irq/irqdomain.c
>> +++ b/kernel/irq/irqdomain.c
>> @@ -839,9 +839,12 @@ int irq_domain_xlate_onetwocell(struct irq_domain *d,
>> {
>> if (WARN_ON(intsize < 1))
>> return -EINVAL;
>> - *out_hwirq = intspec[0];
>> - *out_type = (intsize > 1) ? intspec[1] : IRQ_TYPE_NONE;
>> - return 0;
>> + if (intsize == 1)
>> + return irq_domain_xlate_onecell(d, ctrlr, intspec, intsize,
>> + out_hwirq, out_type);
>> + else
>> + return irq_domain_xlate_twocell(d, ctrlr, intspec, intsize,
>> + out_hwirq, out_type);
>
> So I really wonder how much of a saving that change is. I wouldn't be
> surprised if it would create worse code on some architectures.
>
Maybe it does, although I looked at this from the point of view of reducing
duplicated code because of the well known issues duplicated code entails.
This case is a good example, since the code was duplicated we ended up with
slightly different versions of it.
Best regards,
Sebastian
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH v2] irqdomain: factorise irq_domain_xlate_onetwocell()
2016-08-02 8:31 ` Sebastian Frias
@ 2016-08-02 9:07 ` Sebastian Frias
0 siblings, 0 replies; 5+ messages in thread
From: Sebastian Frias @ 2016-08-02 9:07 UTC (permalink / raw)
To: Thomas Gleixner; +Cc: Grant Likely, Marc Zyngier, Jason Cooper, LKML, Mason
Hi Thomas,
On 08/02/2016 10:31 AM, Sebastian Frias wrote:
>> So the proper way to do that is to split this into two patches:
>>
>> #1 Change the existing code to do the masking and explain why it is correct.
>>
>> #2 Refactor the code and get rid of the duplicated implementation.
>
> Ok, I can do two patches.
I splitted it in two patches, one to fix it, and another one to refactor.
However, I sent the first one (the one for the fix) as a separate one, instead of as
part of a set of two patches.
I'm resending both as a set of two patches (since the second one requires the first
one), sorry for the inconvenience.
Best regards,
Sebastian
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2016-08-02 9:30 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-08-01 14:27 [PATCH] irqdomain: factorise irq_domain_xlate_onetwocell() Sebastian Frias
2016-08-01 14:57 ` [PATCH v2] " Sebastian Frias
2016-08-01 17:07 ` Thomas Gleixner
2016-08-02 8:31 ` Sebastian Frias
2016-08-02 9:07 ` Sebastian Frias
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox