[PATCH 12/13] hrtimer: optimize hrtimer_get_remaining

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



hrtimer_get_remaining doesn't need to lock the hrtimer_base to read the
time. Also use hrtimer_get_remaining at two other places.

Signed-off-by: Roman Zippel <[email protected]>

 kernel/hrtimer.c |   18 +++---------------
 1 file changed, 3 insertions(+), 15 deletions(-)

Index: linux-2.6-git/kernel/hrtimer.c
===================================================================
--- linux-2.6-git.orig/kernel/hrtimer.c	2006-02-13 01:39:19.000000000 +0100
+++ linux-2.6-git/kernel/hrtimer.c	2006-02-13 01:41:59.000000000 +0100
@@ -482,15 +482,7 @@ int hrtimer_cancel(struct hrtimer *timer
  */
 ktime_t hrtimer_get_remaining(const struct hrtimer *timer)
 {
-	struct hrtimer_base *base;
-	unsigned long flags;
-	ktime_t rem;
-
-	base = lock_hrtimer_base(timer, &flags);
-	rem = ktime_sub(timer->expires, timer->base->get_time());
-	unlock_hrtimer_base(timer, &flags);
-
-	return rem;
+	return ktime_sub(timer->expires, timer->base->get_time());
 }
 
 /**
@@ -639,7 +631,6 @@ static long __sched nanosleep_restart(st
 	struct sleep_hrtimer t;
 	struct timespec __user *rmtp;
 	struct timespec tu;
-	ktime_t time;
 
 	restart->fn = do_no_restart_syscall;
 
@@ -650,8 +641,7 @@ static long __sched nanosleep_restart(st
 
 	rmtp = (struct timespec __user *) restart->arg2;
 	if (rmtp) {
-		time = ktime_sub(t.timer.expires, t.timer.base->get_time());
-		tu = ktime_to_timespec(time);
+		tu = ktime_to_timespec(hrtimer_get_remaining(&t.timer));
 		if (copy_to_user(rmtp, &tu, sizeof(tu)))
 			return -EFAULT;
 	}
@@ -668,7 +658,6 @@ long hrtimer_nanosleep(struct timespec *
 	struct restart_block *restart;
 	struct sleep_hrtimer t;
 	struct timespec tu;
-	ktime_t rem;
 
 	hrtimer_init(&t.timer, clockid, mode);
 	t.timer.expires = timespec_to_ktime(*rqtp);
@@ -680,8 +669,7 @@ long hrtimer_nanosleep(struct timespec *
 		return -ERESTARTNOHAND;
 
 	if (rmtp) {
-		rem = ktime_sub(t.timer.expires, t.timer.base->get_time());
-		tu = ktime_to_timespec(rem);
+		tu = ktime_to_timespec(hrtimer_get_remaining(&t.timer));
 		if (copy_to_user(rmtp, &tu, sizeof(tu)))
 			return -EFAULT;
 	}
-
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/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux