linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH RESEND] rtsx_usb_ms: Use msleep_interruptible() in polling loop
@ 2015-09-28  0:34 Ben Hutchings
  2015-09-28 10:34 ` Lee Jones
                   ` (2 more replies)
  0 siblings, 3 replies; 12+ messages in thread
From: Ben Hutchings @ 2015-09-28  0:34 UTC (permalink / raw)
  To: Maxim Levitsky, Roger Tseng; +Cc: LKML, Lee Jones

[-- Attachment #1: Type: text/plain, Size: 822 bytes --]

rtsx_usb_ms creates a task that mostly sleeps, but tasks in
uninterruptible sleep still contribute to the load average (for
bug-compatibility with Unix).  A load average of ~1 on a system that
should be idle is somewhat alarming.

Change the sleep to be interruptible, but still ignore signals.

A better fix might be to replace this loop with a delayed work item.

References: https://bugs.debian.org/765717
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
---
--- a/drivers/memstick/host/rtsx_usb_ms.c
+++ b/drivers/memstick/host/rtsx_usb_ms.c
@@ -706,7 +706,8 @@ poll_again:
 		if (host->eject)
 			break;
 
-		msleep(1000);
+		if (msleep_interruptible(1000))
+			flush_signals(current);
 	}
 
 	complete(&host->detect_ms_exit);
-- 
Ben Hutchings
All extremists should be taken out and shot.

[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 811 bytes --]

^ permalink raw reply	[flat|nested] 12+ messages in thread
* [PATCH RESEND] rtsx_usb_ms: Use msleep_interruptible() in polling loop
@ 2016-05-02 20:17 Oleksandr Natalenko
  2016-05-02 20:56 ` Andrew Morton
  0 siblings, 1 reply; 12+ messages in thread
From: Oleksandr Natalenko @ 2016-05-02 20:17 UTC (permalink / raw)
  To: Ben Hutchings
  Cc: Andrew Morton, Lee Jones, Wolfram Sang, Roger Tseng, linux-kernel

This patch has already been posted to LKML by Ben Hutchings ~6 months
ago, but AFAIK no further action were performed. However, this patch
really fixes weird loadavg with RTS5129 card reader, so I would wonder
if this could be merged. AFAIK, it has been applied to some distros'
kernels, e.g., Ubuntu.

Original Ben's message goes below.

rtsx_usb_ms creates a task that mostly sleeps, but tasks in
uninterruptible sleep still contribute to the load average (for
bug-compatibility with Unix).  A load average of ~1 on a system that
should be idle is somewhat alarming.

Change the sleep to be interruptible, but still ignore signals.

A better fix might be to replace this loop with a delayed work item.

References: https://bugs.debian.org/765717
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
Signed-off-by: Oleksandr Natalenko <oleksandr@natalenko.name>
---
  drivers/memstick/host/rtsx_usb_ms.c | 3 ++-
  1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/drivers/memstick/host/rtsx_usb_ms.c 
b/drivers/memstick/host/rtsx_usb_ms.c
index 1105db2..645dede 100644
--- a/drivers/memstick/host/rtsx_usb_ms.c
+++ b/drivers/memstick/host/rtsx_usb_ms.c
@@ -706,7 +706,8 @@ poll_again:
  		if (host->eject)
  			break;

-		msleep(1000);
+		if (msleep_interruptible(1000))
+			flush_signals(current);
  	}

  	complete(&host->detect_ms_exit);
-- 
2.8.2

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

end of thread, other threads:[~2016-05-03 15:23 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-09-28  0:34 [PATCH RESEND] rtsx_usb_ms: Use msleep_interruptible() in polling loop Ben Hutchings
2015-09-28 10:34 ` Lee Jones
2015-09-28 11:10   ` Ben Hutchings
2015-09-28 11:23     ` Lee Jones
2015-10-08  3:37 ` Roger Tseng
2015-10-08  7:19 ` Lee Jones
2015-10-08 19:35   ` Ben Hutchings
2015-10-09  7:18     ` Lee Jones
  -- strict thread matches above, loose matches on Subject: below --
2016-05-02 20:17 Oleksandr Natalenko
2016-05-02 20:56 ` Andrew Morton
2016-05-03 13:40   ` Oleg Nesterov
2016-05-03 15:22     ` Ben Hutchings

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).