linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions
@ 2015-05-19 10:51 Nicholas Mc Guire
  2015-05-19 14:32 ` Joe Perches
  0 siblings, 1 reply; 8+ messages in thread
From: Nicholas Mc Guire @ 2015-05-19 10:51 UTC (permalink / raw)
  To: Samuel Ortiz; +Cc: netdev, linux-kernel, Nicholas Mc Guire

API compliance scanning with coccinelle flagged:

Converting milliseconds to jiffies by "val * HZ / 1000" is technically
is not a clean solution as it does not handle all corner cases correctly.
By changing the conversion to use msecs_to_jiffies(val) conversion is
correct in all cases.

in the current code: 
  mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
for HZ < 100 (e.g. CONFIG_HZ == 64|32 in alpha) this effectively results 
in no delay at all.

Patch was compile tested for x86_64_defconfig (implies CONFIG_USB_IRDA=m)

Patch is against 4.1-rc4 (localversion-next is -next-20150519)

Signed-off-by: Nicholas Mc Guire <hofrat@osadl.org>
---
 drivers/net/irda/irda-usb.c |    4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/drivers/net/irda/irda-usb.c b/drivers/net/irda/irda-usb.c
index f6c9163..f3e4563 100644
--- a/drivers/net/irda/irda-usb.c
+++ b/drivers/net/irda/irda-usb.c
@@ -848,7 +848,9 @@ static void irda_usb_receive(struct urb *urb)
 		 * Jean II */
 		self->rx_defer_timer.function = irda_usb_rx_defer_expired;
 		self->rx_defer_timer.data = (unsigned long) urb;
-		mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
+		mod_timer(&self->rx_defer_timer,
+			  jiffies + (msecs_to_jiffies(10)));
+
 		return;
 	}
 	
-- 
1.7.10.4


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* Re: [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions
  2015-05-19 10:51 [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions Nicholas Mc Guire
@ 2015-05-19 14:32 ` Joe Perches
  2015-05-19 20:45   ` David Miller
  0 siblings, 1 reply; 8+ messages in thread
From: Joe Perches @ 2015-05-19 14:32 UTC (permalink / raw)
  To: Nicholas Mc Guire; +Cc: Samuel Ortiz, netdev, linux-kernel

On Tue, 2015-05-19 at 12:51 +0200, Nicholas Mc Guire wrote:
> Converting milliseconds to jiffies by "val * HZ / 1000" is technically
> is not a clean solution as it does not handle all corner cases correctly.
> By changing the conversion to use msecs_to_jiffies(val) conversion is
> correct in all cases.
> 
> in the current code: 
>   mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
> for HZ < 100 (e.g. CONFIG_HZ == 64|32 in alpha) this effectively results 
> in no delay at all.
[]
> diff --git a/drivers/net/irda/irda-usb.c b/drivers/net/irda/irda-usb.c
[]
> @@ -848,7 +848,9 @@ static void irda_usb_receive(struct urb *urb)
>  		 * Jean II */
>  		self->rx_defer_timer.function = irda_usb_rx_defer_expired;
>  		self->rx_defer_timer.data = (unsigned long) urb;
> -		mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
> +		mod_timer(&self->rx_defer_timer,
> +			  jiffies + (msecs_to_jiffies(10)));

The unnecessary () around msecs_to_jiffies could be removed.



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions
  2015-05-19 14:32 ` Joe Perches
@ 2015-05-19 20:45   ` David Miller
  2015-05-19 21:09     ` Joe Perches
  0 siblings, 1 reply; 8+ messages in thread
From: David Miller @ 2015-05-19 20:45 UTC (permalink / raw)
  To: joe; +Cc: hofrat, samuel, netdev, linux-kernel

From: Joe Perches <joe@perches.com>
Date: Tue, 19 May 2015 07:32:15 -0700

> On Tue, 2015-05-19 at 12:51 +0200, Nicholas Mc Guire wrote:
>> Converting milliseconds to jiffies by "val * HZ / 1000" is technically
>> is not a clean solution as it does not handle all corner cases correctly.
>> By changing the conversion to use msecs_to_jiffies(val) conversion is
>> correct in all cases.
>> 
>> in the current code: 
>>   mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
>> for HZ < 100 (e.g. CONFIG_HZ == 64|32 in alpha) this effectively results 
>> in no delay at all.
> []
>> diff --git a/drivers/net/irda/irda-usb.c b/drivers/net/irda/irda-usb.c
> []
>> @@ -848,7 +848,9 @@ static void irda_usb_receive(struct urb *urb)
>>  		 * Jean II */
>>  		self->rx_defer_timer.function = irda_usb_rx_defer_expired;
>>  		self->rx_defer_timer.data = (unsigned long) urb;
>> -		mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
>> +		mod_timer(&self->rx_defer_timer,
>> +			  jiffies + (msecs_to_jiffies(10)));
> 
> The unnecessary () around msecs_to_jiffies could be removed.

Agreed.

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions
  2015-05-19 20:45   ` David Miller
@ 2015-05-19 21:09     ` Joe Perches
  2015-05-20  1:44       ` Guenter Roeck
  0 siblings, 1 reply; 8+ messages in thread
From: Joe Perches @ 2015-05-19 21:09 UTC (permalink / raw)
  To: David Miller; +Cc: hofrat, samuel, netdev, linux-kernel

On Tue, 2015-05-19 at 16:45 -0400, David Miller wrote:
> From: Joe Perches <joe@perches.com>
> Date: Tue, 19 May 2015 07:32:15 -0700
> 
> > On Tue, 2015-05-19 at 12:51 +0200, Nicholas Mc Guire wrote:
> >> Converting milliseconds to jiffies by "val * HZ / 1000" is technically
> >> is not a clean solution as it does not handle all corner cases correctly.
> >> By changing the conversion to use msecs_to_jiffies(val) conversion is
> >> correct in all cases.
> >> 
> >> in the current code: 
> >>   mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
> >> for HZ < 100 (e.g. CONFIG_HZ == 64|32 in alpha) this effectively results 
> >> in no delay at all.
> > []
> >> diff --git a/drivers/net/irda/irda-usb.c b/drivers/net/irda/irda-usb.c
> > []
> >> @@ -848,7 +848,9 @@ static void irda_usb_receive(struct urb *urb)
> >>  		 * Jean II */
> >>  		self->rx_defer_timer.function = irda_usb_rx_defer_expired;
> >>  		self->rx_defer_timer.data = (unsigned long) urb;
> >> -		mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
> >> +		mod_timer(&self->rx_defer_timer,
> >> +			  jiffies + (msecs_to_jiffies(10)));
> > 
> > The unnecessary () around msecs_to_jiffies could be removed.

The other thing that could be done is to use
	max(1ul, msecs_to_jiffies())
so that there's always some delay even if HZ <= 50




^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions
  2015-05-19 21:09     ` Joe Perches
@ 2015-05-20  1:44       ` Guenter Roeck
  2015-05-20  3:57         ` Joe Perches
  0 siblings, 1 reply; 8+ messages in thread
From: Guenter Roeck @ 2015-05-20  1:44 UTC (permalink / raw)
  To: Joe Perches; +Cc: David Miller, hofrat, samuel, netdev, linux-kernel

On Tue, May 19, 2015 at 02:09:07PM -0700, Joe Perches wrote:
> On Tue, 2015-05-19 at 16:45 -0400, David Miller wrote:
> > From: Joe Perches <joe@perches.com>
> > Date: Tue, 19 May 2015 07:32:15 -0700
> > 
> > > On Tue, 2015-05-19 at 12:51 +0200, Nicholas Mc Guire wrote:
> > >> Converting milliseconds to jiffies by "val * HZ / 1000" is technically
> > >> is not a clean solution as it does not handle all corner cases correctly.
> > >> By changing the conversion to use msecs_to_jiffies(val) conversion is
> > >> correct in all cases.
> > >> 
> > >> in the current code: 
> > >>   mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
> > >> for HZ < 100 (e.g. CONFIG_HZ == 64|32 in alpha) this effectively results 
> > >> in no delay at all.
> > > []
> > >> diff --git a/drivers/net/irda/irda-usb.c b/drivers/net/irda/irda-usb.c
> > > []
> > >> @@ -848,7 +848,9 @@ static void irda_usb_receive(struct urb *urb)
> > >>  		 * Jean II */
> > >>  		self->rx_defer_timer.function = irda_usb_rx_defer_expired;
> > >>  		self->rx_defer_timer.data = (unsigned long) urb;
> > >> -		mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
> > >> +		mod_timer(&self->rx_defer_timer,
> > >> +			  jiffies + (msecs_to_jiffies(10)));
> > > 
> > > The unnecessary () around msecs_to_jiffies could be removed.
> 
> The other thing that could be done is to use
> 	max(1ul, msecs_to_jiffies())
> so that there's always some delay even if HZ <= 50
> 
I may be mistaken, but I am quite sure that msecs_to_jiffies() always returns
at least 1 in such situations. Otherwise there would be lots of converstions
to 0 in the kernel.

Guenter

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions
  2015-05-20  1:44       ` Guenter Roeck
@ 2015-05-20  3:57         ` Joe Perches
  0 siblings, 0 replies; 8+ messages in thread
From: Joe Perches @ 2015-05-20  3:57 UTC (permalink / raw)
  To: Guenter Roeck; +Cc: David Miller, hofrat, samuel, netdev, linux-kernel

On Tue, 2015-05-19 at 18:44 -0700, Guenter Roeck wrote:
> On Tue, May 19, 2015 at 02:09:07PM -0700, Joe Perches wrote:
> > The other thing that could be done is to use
> > 	max(1ul, msecs_to_jiffies())
> > so that there's always some delay even if HZ <= 50
> > 
> I may be mistaken, but I am quite sure that msecs_to_jiffies() always returns
> at least 1 in such situations. Otherwise there would be lots of conversions
> to 0 in the kernel.

Thanks Guenter

Nope, you're not mistaken.

Non 0 constants always return a value > 0

The existing uses like max(1ul, msecs_to_jiffies(<variable>))
just guard against <variable> being 0.



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions
  2015-05-23 12:46 Nicholas Mc Guire
@ 2015-05-25 21:39 ` David Miller
  0 siblings, 0 replies; 8+ messages in thread
From: David Miller @ 2015-05-25 21:39 UTC (permalink / raw)
  To: hofrat; +Cc: samuel, joe, netdev, linux-kernel

From: Nicholas Mc Guire <hofrat@osadl.org>
Date: Sat, 23 May 2015 14:46:30 +0200

> API compliance scanning with coccinelle flagged:
> 
> Converting milliseconds to jiffies by "val * HZ / 1000" is technically
> is not a clean solution as it does not handle all corner cases correctly.
> By changing the conversion to use msecs_to_jiffies(val) conversion is
> correct in all cases.
> 
> in the current code: 
>   mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
> for HZ < 100 (e.g. CONFIG_HZ == 64|32 in alpha) this effectively results 
> in no delay at all.
> 
> Patch was compile tested for x86_64_defconfig (implies CONFIG_USB_IRDA=m)
> 
> Patch is against 4.1-rc4 (localversion-next is -next-20150522)
> 
> Signed-off-by: Nicholas Mc Guire <hofrat@osadl.org>

Applied to net-next, thanks.

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions
@ 2015-05-23 12:46 Nicholas Mc Guire
  2015-05-25 21:39 ` David Miller
  0 siblings, 1 reply; 8+ messages in thread
From: Nicholas Mc Guire @ 2015-05-23 12:46 UTC (permalink / raw)
  To: Samuel Ortiz
  Cc: David Miller, Joe Perches, netdev, linux-kernel, Nicholas Mc Guire

API compliance scanning with coccinelle flagged:

Converting milliseconds to jiffies by "val * HZ / 1000" is technically
is not a clean solution as it does not handle all corner cases correctly.
By changing the conversion to use msecs_to_jiffies(val) conversion is
correct in all cases.

in the current code: 
  mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
for HZ < 100 (e.g. CONFIG_HZ == 64|32 in alpha) this effectively results 
in no delay at all.

Patch was compile tested for x86_64_defconfig (implies CONFIG_USB_IRDA=m)

Patch is against 4.1-rc4 (localversion-next is -next-20150522)

Signed-off-by: Nicholas Mc Guire <hofrat@osadl.org>
---

V2: the unnecessary () flagged by Joe Perches <joe@perches.com>
    was removed - thanks (...once again...) !

 drivers/net/irda/irda-usb.c |    4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/drivers/net/irda/irda-usb.c b/drivers/net/irda/irda-usb.c
index f6c9163..f3e4563 100644
--- a/drivers/net/irda/irda-usb.c
+++ b/drivers/net/irda/irda-usb.c
@@ -848,7 +848,9 @@ static void irda_usb_receive(struct urb *urb)
 		 * Jean II */
 		self->rx_defer_timer.function = irda_usb_rx_defer_expired;
 		self->rx_defer_timer.data = (unsigned long) urb;
-		mod_timer(&self->rx_defer_timer, jiffies + (10 * HZ / 1000));
+		mod_timer(&self->rx_defer_timer,
+			  jiffies + msecs_to_jiffies(10));
+
 		return;
 	}
 	
-- 
1.7.10.4


^ permalink raw reply related	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2015-05-25 21:39 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-05-19 10:51 [PATCH] irda: irda-usb: use msecs_to_jiffies for conversions Nicholas Mc Guire
2015-05-19 14:32 ` Joe Perches
2015-05-19 20:45   ` David Miller
2015-05-19 21:09     ` Joe Perches
2015-05-20  1:44       ` Guenter Roeck
2015-05-20  3:57         ` Joe Perches
2015-05-23 12:46 Nicholas Mc Guire
2015-05-25 21:39 ` David Miller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).