aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2006-01-12 05:36:14 -0500
committerThomas Gleixner <tglx@linutronix.de>2006-01-12 05:36:14 -0500
commite2787630c1abb075c935cf47e91beb7c656f48c4 (patch)
tree43b6ee44b9f81fdb33283313f167d6ecec2b0243
parent288867ec5c377db82933b64460ce050e5c998ee9 (diff)
[hrtimer] Change resolution storage to ktime_t format
Change the storage format of the per base resolution to ktime_t to make it easier accessible in the hrtimers code. Change the resolution from (NSEC_PER_SEC/HZ) to TICK_NSEC as Roman pointed out. TICK_NSEC is closer to the real resolution. Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r--include/linux/hrtimer.h2
-rw-r--r--include/linux/ktime.h4
-rw-r--r--kernel/hrtimer.c3
3 files changed, 4 insertions, 5 deletions
diff --git a/include/linux/hrtimer.h b/include/linux/hrtimer.h
index abb674c9b764..98c5c1537b5d 100644
--- a/include/linux/hrtimer.h
+++ b/include/linux/hrtimer.h
@@ -85,7 +85,7 @@ struct hrtimer_base {
85 spinlock_t lock; 85 spinlock_t lock;
86 struct rb_root active; 86 struct rb_root active;
87 struct rb_node *first; 87 struct rb_node *first;
88 unsigned long resolution; 88 ktime_t resolution;
89 ktime_t (*get_time)(void); 89 ktime_t (*get_time)(void);
90 struct hrtimer *curr_timer; 90 struct hrtimer *curr_timer;
91}; 91};
diff --git a/include/linux/ktime.h b/include/linux/ktime.h
index 222a047cc145..1bd6552cc341 100644
--- a/include/linux/ktime.h
+++ b/include/linux/ktime.h
@@ -272,8 +272,8 @@ static inline u64 ktime_to_ns(const ktime_t kt)
272 * idea of the (in)accuracy of timers. Timer values are rounded up to 272 * idea of the (in)accuracy of timers. Timer values are rounded up to
273 * this resolution values. 273 * this resolution values.
274 */ 274 */
275#define KTIME_REALTIME_RES (NSEC_PER_SEC/HZ) 275#define KTIME_REALTIME_RES (ktime_t){ .tv64 = TICK_NSEC }
276#define KTIME_MONOTONIC_RES (NSEC_PER_SEC/HZ) 276#define KTIME_MONOTONIC_RES (ktime_t){ .tv64 = TICK_NSEC }
277 277
278/* Get the monotonic time in timespec format: */ 278/* Get the monotonic time in timespec format: */
279extern void ktime_get_ts(struct timespec *ts); 279extern void ktime_get_ts(struct timespec *ts);
diff --git a/kernel/hrtimer.c b/kernel/hrtimer.c
index e6e8278bcb18..76d759ce6231 100644
--- a/kernel/hrtimer.c
+++ b/kernel/hrtimer.c
@@ -518,9 +518,8 @@ int hrtimer_get_res(const clockid_t which_clock, struct timespec *tp)
518{ 518{
519 struct hrtimer_base *bases; 519 struct hrtimer_base *bases;
520 520
521 tp->tv_sec = 0;
522 bases = per_cpu(hrtimer_bases, raw_smp_processor_id()); 521 bases = per_cpu(hrtimer_bases, raw_smp_processor_id());
523 tp->tv_nsec = bases[which_clock].resolution; 522 *tp = ktime_to_timespec(bases[which_clock].resolution);
524 523
525 return 0; 524 return 0;
526} 525}