aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorMartin Schwidefsky <schwidefsky@de.ibm.com>2011-08-23 09:29:43 -0400
committerThomas Gleixner <tglx@linutronix.de>2011-09-08 05:10:56 -0400
commit65516f8a7c2028381f0dae4c16ddb621c96158cc (patch)
tree1f6192832c77e25499331b074398e165c1220197 /kernel
parentd1748302f70be7469809809283fe164156a34231 (diff)
clockevents: Add direct ktime programming function
There is at least one architecture (s390) with a sane clockevent device that can be programmed with the equivalent of a ktime. No need to create a delta against the current time, the ktime can be used directly. A new clock device function 'set_next_ktime' is introduced that is called with the unmodified ktime for the timer if the clock event device has the CLOCK_EVT_FEAT_KTIME bit set. Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com> Cc: john stultz <johnstul@us.ibm.com> Link: http://lkml.kernel.org/r/20110823133142.815350967@de.ibm.com Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/time/clockevents.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/kernel/time/clockevents.c b/kernel/time/clockevents.c
index 713ef94eceef..1ecd6ba36d6c 100644
--- a/kernel/time/clockevents.c
+++ b/kernel/time/clockevents.c
@@ -216,6 +216,10 @@ int clockevents_program_event(struct clock_event_device *dev, ktime_t expires,
216 if (dev->mode == CLOCK_EVT_MODE_SHUTDOWN) 216 if (dev->mode == CLOCK_EVT_MODE_SHUTDOWN)
217 return 0; 217 return 0;
218 218
219 /* Shortcut for clockevent devices that can deal with ktime. */
220 if (dev->features & CLOCK_EVT_FEAT_KTIME)
221 return dev->set_next_ktime(expires, dev);
222
219 delta = ktime_to_ns(ktime_sub(expires, ktime_get())); 223 delta = ktime_to_ns(ktime_sub(expires, ktime_get()));
220 if (delta <= 0) 224 if (delta <= 0)
221 return force ? clockevents_program_min_delta(dev) : -ETIME; 225 return force ? clockevents_program_min_delta(dev) : -ETIME;