diff options
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 | } | ||
