Please consider applying. 

Use msleep_interruptible() instead of schedule_timeout() to
guarantee consistent timing regardless of HZ value. schedule_timeout(1) will
vary between 10 and 1 milliseconds, depending on the value of HZ (100 or 1000
respectively). For consistent behavior, msleep_interruptible() should be used.

Signed-off-by: Nishanth Aravamudan <[EMAIL PROTECTED]>
Signed-off-by: Domen Puncer <[EMAIL PROTECTED]>
---


 kj-domen/drivers/char/sx.c |    8 ++------
 1 files changed, 2 insertions(+), 6 deletions(-)

diff -puN drivers/char/sx.c~msleep_interruptible-drivers_char_sx 
drivers/char/sx.c
--- kj/drivers/char/sx.c~msleep_interruptible-drivers_char_sx   2005-03-05 
16:11:01.000000000 +0100
+++ kj-domen/drivers/char/sx.c  2005-03-05 16:11:01.000000000 +0100
@@ -1515,13 +1515,9 @@ static void sx_close (void *ptr)
        sx_reconfigure_port(port);      
        sx_send_command (port, HS_CLOSE, 0, 0);
 
-       while (to-- && (sx_read_channel_byte (port, hi_hstat) != 
HS_IDLE_CLOSED)) {
-               set_current_state(TASK_INTERRUPTIBLE);
-               schedule_timeout (1);
-               if (signal_pending (current))
+       while (to-- && (sx_read_channel_byte (port, hi_hstat) != 
HS_IDLE_CLOSED))
+               if (msleep_interruptible(10))
                                break;
-       }
-       current->state = TASK_RUNNING;
        if (sx_read_channel_byte (port, hi_hstat) != HS_IDLE_CLOSED) {
                if (sx_send_command (port, HS_FORCE_CLOSED, -1, HS_IDLE_CLOSED) 
!= 1) {
                        printk (KERN_ERR 
_
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to