<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">From: Vojtech Pavlik &lt;vojtech@suse.cz&gt;

input: The timeout while() loops in iforce-packets.c lack a
set_current_state(TASK_INTERRUPTIBLE); call. The right solution is
to replace them with wait_event_interruptible_timeout().

Reported-by: Nishanth Aravamudan &lt;nacc@us.ibm.com&gt;
Signed-off-by: Vojtech Pavlik &lt;vojtech@suse.cz&gt;

Index: dmitry/drivers/input/joystick/iforce/iforce-usb.c
===================================================================
--- dmitry.orig/drivers/input/joystick/iforce/iforce-usb.c	2005-06-27 15:13:50.000000000 +0200
+++ dmitry/drivers/input/joystick/iforce/iforce-usb.c	2005-07-07 15:23:51.000000000 +0200
@@ -95,6 +95,7 @@
 		goto exit;
 	}
 
+	wake_up(&amp;iforce-&gt;wait);
 	iforce_process_packet(iforce,
 		(iforce-&gt;data[0] &lt;&lt; 8) | (urb-&gt;actual_length - 1), iforce-&gt;data + 1, regs);
 
Index: dmitry/drivers/input/joystick/iforce/iforce-packets.c
===================================================================
--- dmitry.orig/drivers/input/joystick/iforce/iforce-packets.c	2005-06-27 15:13:50.000000000 +0200
+++ dmitry/drivers/input/joystick/iforce/iforce-packets.c	2005-07-07 15:26:48.000000000 +0200
@@ -249,9 +249,6 @@
 
 int iforce_get_id_packet(struct iforce *iforce, char *packet)
 {
-	DECLARE_WAITQUEUE(wait, current);
-	int timeout = HZ; /* 1 second */
-
 	switch (iforce-&gt;bus) {
 
 	case IFORCE_USB:
@@ -260,22 +257,13 @@
 		iforce-&gt;cr.bRequest = packet[0];
 		iforce-&gt;ctrl-&gt;dev = iforce-&gt;usbdev;
 
-		set_current_state(TASK_INTERRUPTIBLE);
-		add_wait_queue(&amp;iforce-&gt;wait, &amp;wait);
-
-		if (usb_submit_urb(iforce-&gt;ctrl, GFP_ATOMIC)) {
-			set_current_state(TASK_RUNNING);
-			remove_wait_queue(&amp;iforce-&gt;wait, &amp;wait);
+		if (usb_submit_urb(iforce-&gt;ctrl, GFP_ATOMIC))
 			return -1;
-		}
 
-		while (timeout &amp;&amp; iforce-&gt;ctrl-&gt;status == -EINPROGRESS)
-			timeout = schedule_timeout(timeout);
+		wait_event_interruptible_timeout(iforce-&gt;wait,
+			iforce-&gt;ctrl-&gt;status != -EINPROGRESS, HZ);
 
-		set_current_state(TASK_RUNNING);
-		remove_wait_queue(&amp;iforce-&gt;wait, &amp;wait);
-
-		if (!timeout) {
+		if (iforce-&gt;ctrl-&gt;status -= -EINPROGRESS) {
 			usb_unlink_urb(iforce-&gt;ctrl);
 			return -1;
 		}
@@ -290,16 +278,10 @@
 		iforce-&gt;expect_packet = FF_CMD_QUERY;
 		iforce_send_packet(iforce, FF_CMD_QUERY, packet);
 
-		set_current_state(TASK_INTERRUPTIBLE);
-		add_wait_queue(&amp;iforce-&gt;wait, &amp;wait);
-
-		while (timeout &amp;&amp; iforce-&gt;expect_packet)
-			timeout = schedule_timeout(timeout);
-
-		set_current_state(TASK_RUNNING);
-		remove_wait_queue(&amp;iforce-&gt;wait, &amp;wait);
+		wait_event_interruptible_timeout(iforce-&gt;wait,
+			!iforce-&gt;expect_packet, HZ);
 
-		if (!timeout) {
+		if (iforce-&gt;expect_packet) {
 			iforce-&gt;expect_packet = 0;
 			return -1;
 		}
</pre></body></html>