[Linux-parport] [patch 1/1] parport/ieee1284: use human-time in sleeping logic

domen at coderock.org domen at coderock.org
Fri May 13 18:23:50 EDT 2005


From: Nishanth Aravamudan <nacc at us.ibm.com>


Be a little more precise with the conversions between milliseconds and
jiffies. Use msleep_interruptible() instead of schedule_timeout() to
guarantee the task delays as expected.

Signed-off-by: Nishanth Aravamudan <nacc at us.ibm.com>
Signed-off-by: Domen Puncer <domen at coderock.org>

---
 ieee1284.c |    8 +++-----
 1 files changed, 3 insertions(+), 5 deletions(-)

Index: quilt/drivers/parport/ieee1284.c
===================================================================
--- quilt.orig/drivers/parport/ieee1284.c
+++ quilt/drivers/parport/ieee1284.c
@@ -196,7 +196,7 @@ int parport_wait_peripheral(struct parpo
 		return 1;
 
 	/* 40ms of slow polling. */
-	deadline = jiffies + (HZ + 24) / 25;
+	deadline = jiffies + msecs_to_jiffies(40);
 	while (time_before (jiffies, deadline)) {
 		int ret;
 
@@ -212,13 +212,11 @@ int parport_wait_peripheral(struct parpo
 		if ((status & mask) == result)
 			return 0;
 
-		if (!ret) {
+		if (!ret)
 			/* parport_wait_event didn't time out, but the
 			 * peripheral wasn't actually ready either.
 			 * Wait for another 10ms. */
-			__set_current_state (TASK_INTERRUPTIBLE);
-			schedule_timeout ((HZ+ 99) / 100);
-		}
+			msleep_interruptible(10);
 	}
 
 	return 1;

--



More information about the Linux-parport mailing list