aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorArjan van de Ven <arjan@linux.intel.com>2008-09-07 13:47:46 -0400
committerArjan van de Ven <arjan@linux.intel.com>2008-09-07 13:58:01 -0400
commitda8f2e170ea94cc20f8ebbc8ee8d127edb8f12f1 (patch)
tree08d25027a7769cd250aca5b516a3d8c95e4385be /kernel
parent2ec02270c00f94b08fddfb68c37510a9fb47ac7c (diff)
hrtimer: add a hrtimer_start_range() function
this patch adds a _range version of hrtimer_start() so that range timers can be created; the hrtimer_start() function is just a wrapper around this. In addition, hrtimer_start_expires() will now preserve existing ranges. Signed-off-by: Arjan van de Ven <arjan@linux.intel.com>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/hrtimer.c26
1 files changed, 23 insertions, 3 deletions
diff --git a/kernel/hrtimer.c b/kernel/hrtimer.c
index 01483004183..a0222097c57 100644
--- a/kernel/hrtimer.c
+++ b/kernel/hrtimer.c
@@ -945,9 +945,10 @@ remove_hrtimer(struct hrtimer *timer, struct hrtimer_clock_base *base)
945} 945}
946 946
947/** 947/**
948 * hrtimer_start - (re)start an relative timer on the current CPU 948 * hrtimer_start_range_ns - (re)start an relative timer on the current CPU
949 * @timer: the timer to be added 949 * @timer: the timer to be added
950 * @tim: expiry time 950 * @tim: expiry time
951 * @delta_ns: "slack" range for the timer
951 * @mode: expiry mode: absolute (HRTIMER_ABS) or relative (HRTIMER_REL) 952 * @mode: expiry mode: absolute (HRTIMER_ABS) or relative (HRTIMER_REL)
952 * 953 *
953 * Returns: 954 * Returns:
@@ -955,7 +956,8 @@ remove_hrtimer(struct hrtimer *timer, struct hrtimer_clock_base *base)
955 * 1 when the timer was active 956 * 1 when the timer was active
956 */ 957 */
957int 958int
958hrtimer_start(struct hrtimer *timer, ktime_t tim, const enum hrtimer_mode mode) 959hrtimer_start_range_ns(struct hrtimer *timer, ktime_t tim, unsigned long delta_ns,
960 const enum hrtimer_mode mode)
959{ 961{
960 struct hrtimer_clock_base *base, *new_base; 962 struct hrtimer_clock_base *base, *new_base;
961 unsigned long flags; 963 unsigned long flags;
@@ -983,7 +985,7 @@ hrtimer_start(struct hrtimer *timer, ktime_t tim, const enum hrtimer_mode mode)
983#endif 985#endif
984 } 986 }
985 987
986 hrtimer_set_expires(timer, tim); 988 hrtimer_set_expires_range_ns(timer, tim, delta_ns);
987 989
988 timer_stats_hrtimer_set_start_info(timer); 990 timer_stats_hrtimer_set_start_info(timer);
989 991
@@ -1016,8 +1018,26 @@ hrtimer_start(struct hrtimer *timer, ktime_t tim, const enum hrtimer_mode mode)
1016 1018
1017 return ret; 1019 return ret;
1018} 1020}
1021EXPORT_SYMBOL_GPL(hrtimer_start_range_ns);
1022
1023/**
1024 * hrtimer_start - (re)start an relative timer on the current CPU
1025 * @timer: the timer to be added
1026 * @tim: expiry time
1027 * @mode: expiry mode: absolute (HRTIMER_ABS) or relative (HRTIMER_REL)
1028 *
1029 * Returns:
1030 * 0 on success
1031 * 1 when the timer was active
1032 */
1033int
1034hrtimer_start(struct hrtimer *timer, ktime_t tim, const enum hrtimer_mode mode)
1035{
1036 return hrtimer_start_range_ns(timer, tim, 0, mode);
1037}
1019EXPORT_SYMBOL_GPL(hrtimer_start); 1038EXPORT_SYMBOL_GPL(hrtimer_start);
1020 1039
1040
1021/** 1041/**
1022 * hrtimer_try_to_cancel - try to deactivate a timer 1042 * hrtimer_try_to_cancel - try to deactivate a timer
1023 * @timer: hrtimer to stop 1043 * @timer: hrtimer to stop