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 /kernel | |
| 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>
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/hrtimer.c | 13 | ||||
| -rw-r--r-- | kernel/time/timekeeping.c | 16 |
2 files changed, 18 insertions, 11 deletions
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 | } | ||
