public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [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