From bcc44f1f52d89062d4bb7585cb43138b10871940 Mon Sep 17 00:00:00 2001 From: Patrick Pannuto Date: Mon, 2 Aug 2010 15:01:04 -0700 Subject: [PATCH] --- yaml --- r: 206139 b: refs/heads/master c: 5e7f5a178bba45c5aca3448fddecabd4e28f1f6b h: refs/heads/master i: 206137: 0b4c803be2bac8933ee621b548a231753ae02c7a 206135: 7010e7c88c76961be4cf9f4c96a0c669365e320e v: v3 --- [refs] | 2 +- trunk/include/linux/delay.h | 1 + trunk/kernel/timer.c | 22 ++++++++++++++++++++++ 3 files changed, 24 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index e093bd9c754a..31e24b184516 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: e1b004c3ef9c59db5f013528628b51c8653155ec +refs/heads/master: 5e7f5a178bba45c5aca3448fddecabd4e28f1f6b diff --git a/trunk/include/linux/delay.h b/trunk/include/linux/delay.h index fd832c6d419e..a6ecb34cf547 100644 --- a/trunk/include/linux/delay.h +++ b/trunk/include/linux/delay.h @@ -45,6 +45,7 @@ extern unsigned long lpj_fine; void calibrate_delay(void); void msleep(unsigned int msecs); unsigned long msleep_interruptible(unsigned int msecs); +void usleep_range(unsigned long min, unsigned long max); static inline void ssleep(unsigned int seconds) { diff --git a/trunk/kernel/timer.c b/trunk/kernel/timer.c index ce98685cd1cb..723a62e86dcb 100644 --- a/trunk/kernel/timer.c +++ b/trunk/kernel/timer.c @@ -1755,3 +1755,25 @@ unsigned long msleep_interruptible(unsigned int msecs) } EXPORT_SYMBOL(msleep_interruptible); + +static int __sched do_usleep_range(unsigned long min, unsigned long max) +{ + ktime_t kmin; + unsigned long delta; + + kmin = ktime_set(0, min * NSEC_PER_USEC); + delta = (max - min) * NSEC_PER_USEC; + return schedule_hrtimeout_range(&kmin, delta, HRTIMER_MODE_REL); +} + +/** + * usleep_range - Drop in replacement for udelay where wakeup is flexible + * @min: Minimum time in usecs to sleep + * @max: Maximum time in usecs to sleep + */ +void usleep_range(unsigned long min, unsigned long max) +{ + __set_current_state(TASK_UNINTERRUPTIBLE); + do_usleep_range(min, max); +} +EXPORT_SYMBOL(usleep_range);