diff options
author | Torben Hohn <torbenh@gmx.de> | 2011-01-27 09:59:05 -0500 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2011-01-31 08:55:42 -0500 |
commit | 48cf76f7104f655bbd48a75c7759dce82c3e1ab6 (patch) | |
tree | 2b3cf138fd277ba9c551d75ccbe575a40974560a | |
parent | fbad1ea94159a71bc0f68b00e57ae803606af9fb (diff) |
time: Provide get_xtime_and_monotonic_offset()
The hrtimer code accesses timekeeping variables under
xtime_lock. Provide a sensible accessor function and use it.
[ tglx: Removed the conditionals, unused variable, fixed codingstyle
and massaged changelog ]
Signed-off-by: Torben Hohn <torbenh@gmx.de>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: johnstul@us.ibm.com
Cc: yong.zhang0@gmail.com
Cc: hch@infradead.org
LKML-Reference: <20110127145905.23248.30458.stgit@localhost>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r-- | include/linux/time.h | 1 | ||||
-rw-r--r-- | kernel/hrtimer.c | 13 | ||||
-rw-r--r-- | kernel/time/timekeeping.c | 16 |
3 files changed, 19 insertions, 11 deletions
diff --git a/include/linux/time.h b/include/linux/time.h index 86a9c487fdd8..4007a12a1b50 100644 --- a/include/linux/time.h +++ b/include/linux/time.h | |||
@@ -127,6 +127,7 @@ struct timespec current_kernel_time(void); | |||
127 | struct timespec __current_kernel_time(void); /* does not take xtime_lock */ | 127 | struct timespec __current_kernel_time(void); /* does not take xtime_lock */ |
128 | struct timespec __get_wall_to_monotonic(void); /* does not take xtime_lock */ | 128 | struct timespec __get_wall_to_monotonic(void); /* does not take xtime_lock */ |
129 | struct timespec get_monotonic_coarse(void); | 129 | struct timespec get_monotonic_coarse(void); |
130 | void get_xtime_and_monotonic_offset(struct timespec *xtim, struct timespec *wtom); | ||
130 | 131 | ||
131 | #define CURRENT_TIME (current_kernel_time()) | 132 | #define CURRENT_TIME (current_kernel_time()) |
132 | #define CURRENT_TIME_SEC ((struct timespec) { get_seconds(), 0 }) | 133 | #define CURRENT_TIME_SEC ((struct timespec) { get_seconds(), 0 }) |
diff --git a/kernel/hrtimer.c b/kernel/hrtimer.c index 0c8d7c048615..57c4d33c9a9d 100644 --- a/kernel/hrtimer.c +++ b/kernel/hrtimer.c | |||
@@ -85,13 +85,8 @@ static void hrtimer_get_softirq_time(struct hrtimer_cpu_base *base) | |||
85 | { | 85 | { |
86 | ktime_t xtim, tomono; | 86 | ktime_t xtim, tomono; |
87 | struct timespec xts, tom; | 87 | struct timespec xts, tom; |
88 | unsigned long seq; | ||
89 | 88 | ||
90 | do { | 89 | get_xtime_and_monotonic_offset(&xts, &tom); |
91 | seq = read_seqbegin(&xtime_lock); | ||
92 | xts = __current_kernel_time(); | ||
93 | tom = __get_wall_to_monotonic(); | ||
94 | } while (read_seqretry(&xtime_lock, seq)); | ||
95 | 90 | ||
96 | xtim = timespec_to_ktime(xts); | 91 | xtim = timespec_to_ktime(xts); |
97 | tomono = timespec_to_ktime(tom); | 92 | tomono = timespec_to_ktime(tom); |
@@ -612,15 +607,11 @@ static void retrigger_next_event(void *arg) | |||
612 | { | 607 | { |
613 | struct hrtimer_cpu_base *base; | 608 | struct hrtimer_cpu_base *base; |
614 | struct timespec realtime_offset, wtm; | 609 | struct timespec realtime_offset, wtm; |
615 | unsigned long seq; | ||
616 | 610 | ||
617 | if (!hrtimer_hres_active()) | 611 | if (!hrtimer_hres_active()) |
618 | return; | 612 | return; |
619 | 613 | ||
620 | do { | 614 | get_xtime_and_monotonic_offset(&realtime_offset, &wtm); |
621 | seq = read_seqbegin(&xtime_lock); | ||
622 | wtm = __get_wall_to_monotonic(); | ||
623 | } while (read_seqretry(&xtime_lock, seq)); | ||
624 | set_normalized_timespec(&realtime_offset, -wtm.tv_sec, -wtm.tv_nsec); | 615 | set_normalized_timespec(&realtime_offset, -wtm.tv_sec, -wtm.tv_nsec); |
625 | 616 | ||
626 | base = &__get_cpu_var(hrtimer_bases); | 617 | base = &__get_cpu_var(hrtimer_bases); |
diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c index c1a178ca0f50..c50aaf6cd01d 100644 --- a/kernel/time/timekeeping.c +++ b/kernel/time/timekeeping.c | |||
@@ -958,3 +958,19 @@ void do_timer(unsigned long ticks) | |||
958 | update_wall_time(); | 958 | update_wall_time(); |
959 | calc_global_load(ticks); | 959 | calc_global_load(ticks); |
960 | } | 960 | } |
961 | |||
962 | /** | ||
963 | * get_xtime_and_monotonic_offset() - get xtime and wall_to_monotonic | ||
964 | * @xtim: pointer to timespec to be set with xtime | ||
965 | * @wtom: pointer to timespec to be set with wall_to_monotonic | ||
966 | */ | ||
967 | void get_xtime_and_monotonic_offset(struct timespec *xtim, struct timespec *wtom) | ||
968 | { | ||
969 | unsigned long seq; | ||
970 | |||
971 | do { | ||
972 | seq = read_seqbegin(&xtime_lock); | ||
973 | *xtim = xtime; | ||
974 | *wtom = wall_to_monotonic; | ||
975 | } while (read_seqretry(&xtime_lock, seq)); | ||
976 | } | ||