[media] staging: sir: use usleep_range() rather than busy looping
authorSean Young <sean@mess.org>
Tue, 7 Mar 2017 20:01:48 +0000 (17:01 -0300)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Wed, 5 Apr 2017 17:49:02 +0000 (14:49 -0300)
usleep_range() is perfect for this.

Signed-off-by: Sean Young <sean@mess.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
drivers/staging/media/lirc/lirc_sir.c

index 1362900f2ec48d0f97c9094658a9d7c2ca5d6856..e21f163026d8aed15f2e7ea8f940e72e6d5f0f8d 100644 (file)
@@ -76,21 +76,6 @@ static inline void soutp(int offset, int value)
        outb(value, io + offset);
 }
 
-#ifndef MAX_UDELAY_MS
-#define MAX_UDELAY_US 5000
-#else
-#define MAX_UDELAY_US (MAX_UDELAY_MS * 1000)
-#endif
-
-static void safe_udelay(unsigned long usecs)
-{
-       while (usecs > MAX_UDELAY_US) {
-               udelay(MAX_UDELAY_US);
-               usecs -= MAX_UDELAY_US;
-       }
-       udelay(usecs);
-}
-
 /* SECTION: Communication with user-space */
 static int sir_tx_ir(struct rc_dev *dev, unsigned int *tx_buf,
                     unsigned int count)
@@ -281,7 +266,7 @@ static irqreturn_t sir_interrupt(int irq, void *dev_id)
 
 static void send_space(unsigned long len)
 {
-       safe_udelay(len);
+       usleep_range(len, len + 25);
 }
 
 static void send_pulse(unsigned long len)