diff options
author | John Stultz <john.stultz@linaro.org> | 2014-07-16 17:03:52 -0400 |
---|---|---|
committer | John Stultz <john.stultz@linaro.org> | 2014-07-23 13:16:50 -0400 |
commit | 76f4108892d9a9e3408bba839914f97a54086a6f (patch) | |
tree | 9f44cd624fc7781cac2f77630c37013fe24432e6 /kernel/time | |
parent | e06fde37b860f5030e93475a2a95857af7ad13e1 (diff) |
hrtimer: Cleanup hrtimer accessors to the timekepeing state
Rather then having two similar but totally different implementations
that provide timekeeping state to the hrtimer code, try to unify the
two implementations to be more simliar.
Thus this clarifies ktime_get_update_offsets to
ktime_get_update_offsets_now and changes get_xtime... to
ktime_get_update_offsets_tick.
Signed-off-by: John Stultz <john.stultz@linaro.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: John Stultz <john.stultz@linaro.org>
Diffstat (limited to 'kernel/time')
-rw-r--r-- | kernel/time/hrtimer.c | 19 | ||||
-rw-r--r-- | kernel/time/timekeeping.c | 36 |
2 files changed, 31 insertions, 24 deletions
diff --git a/kernel/time/hrtimer.c b/kernel/time/hrtimer.c index 66a6dc1075ad..2f4ef8a1e5ff 100644 --- a/kernel/time/hrtimer.c +++ b/kernel/time/hrtimer.c | |||
@@ -114,21 +114,18 @@ static inline int hrtimer_clockid_to_base(clockid_t clock_id) | |||
114 | */ | 114 | */ |
115 | static void hrtimer_get_softirq_time(struct hrtimer_cpu_base *base) | 115 | static void hrtimer_get_softirq_time(struct hrtimer_cpu_base *base) |
116 | { | 116 | { |
117 | ktime_t xtim, mono, boot; | 117 | ktime_t xtim, mono, boot, tai; |
118 | struct timespec xts, tom, slp; | 118 | ktime_t off_real, off_boot, off_tai; |
119 | s32 tai_offset; | ||
120 | 119 | ||
121 | get_xtime_and_monotonic_and_sleep_offset(&xts, &tom, &slp); | 120 | mono = ktime_get_update_offsets_tick(&off_real, &off_boot, &off_tai); |
122 | tai_offset = timekeeping_get_tai_offset(); | 121 | boot = ktime_add(mono, off_boot); |
122 | xtim = ktime_add(mono, off_real); | ||
123 | tai = ktime_add(xtim, off_tai); | ||
123 | 124 | ||
124 | xtim = timespec_to_ktime(xts); | ||
125 | mono = ktime_add(xtim, timespec_to_ktime(tom)); | ||
126 | boot = ktime_add(mono, timespec_to_ktime(slp)); | ||
127 | base->clock_base[HRTIMER_BASE_REALTIME].softirq_time = xtim; | 125 | base->clock_base[HRTIMER_BASE_REALTIME].softirq_time = xtim; |
128 | base->clock_base[HRTIMER_BASE_MONOTONIC].softirq_time = mono; | 126 | base->clock_base[HRTIMER_BASE_MONOTONIC].softirq_time = mono; |
129 | base->clock_base[HRTIMER_BASE_BOOTTIME].softirq_time = boot; | 127 | base->clock_base[HRTIMER_BASE_BOOTTIME].softirq_time = boot; |
130 | base->clock_base[HRTIMER_BASE_TAI].softirq_time = | 128 | base->clock_base[HRTIMER_BASE_TAI].softirq_time = tai; |
131 | ktime_add(xtim, ktime_set(tai_offset, 0)); | ||
132 | } | 129 | } |
133 | 130 | ||
134 | /* | 131 | /* |
@@ -673,7 +670,7 @@ static inline ktime_t hrtimer_update_base(struct hrtimer_cpu_base *base) | |||
673 | ktime_t *offs_boot = &base->clock_base[HRTIMER_BASE_BOOTTIME].offset; | 670 | ktime_t *offs_boot = &base->clock_base[HRTIMER_BASE_BOOTTIME].offset; |
674 | ktime_t *offs_tai = &base->clock_base[HRTIMER_BASE_TAI].offset; | 671 | ktime_t *offs_tai = &base->clock_base[HRTIMER_BASE_TAI].offset; |
675 | 672 | ||
676 | return ktime_get_update_offsets(offs_real, offs_boot, offs_tai); | 673 | return ktime_get_update_offsets_now(offs_real, offs_boot, offs_tai); |
677 | } | 674 | } |
678 | 675 | ||
679 | /* | 676 | /* |
diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c index 908861c58e62..b94fa3652aaa 100644 --- a/kernel/time/timekeeping.c +++ b/kernel/time/timekeeping.c | |||
@@ -1581,29 +1581,39 @@ void do_timer(unsigned long ticks) | |||
1581 | } | 1581 | } |
1582 | 1582 | ||
1583 | /** | 1583 | /** |
1584 | * get_xtime_and_monotonic_and_sleep_offset() - get xtime, wall_to_monotonic, | 1584 | * ktime_get_update_offsets_tick - hrtimer helper |
1585 | * and sleep offsets. | 1585 | * @offs_real: pointer to storage for monotonic -> realtime offset |
1586 | * @xtim: pointer to timespec to be set with xtime | 1586 | * @offs_boot: pointer to storage for monotonic -> boottime offset |
1587 | * @wtom: pointer to timespec to be set with wall_to_monotonic | 1587 | * @offs_tai: pointer to storage for monotonic -> clock tai offset |
1588 | * @sleep: pointer to timespec to be set with time in suspend | 1588 | * |
1589 | * Returns monotonic time at last tick and various offsets | ||
1589 | */ | 1590 | */ |
1590 | void get_xtime_and_monotonic_and_sleep_offset(struct timespec *xtim, | 1591 | ktime_t ktime_get_update_offsets_tick(ktime_t *offs_real, ktime_t *offs_boot, |
1591 | struct timespec *wtom, struct timespec *sleep) | 1592 | ktime_t *offs_tai) |
1592 | { | 1593 | { |
1593 | struct timekeeper *tk = &timekeeper; | 1594 | struct timekeeper *tk = &timekeeper; |
1594 | unsigned long seq; | 1595 | struct timespec ts; |
1596 | ktime_t now; | ||
1597 | unsigned int seq; | ||
1595 | 1598 | ||
1596 | do { | 1599 | do { |
1597 | seq = read_seqcount_begin(&timekeeper_seq); | 1600 | seq = read_seqcount_begin(&timekeeper_seq); |
1598 | *xtim = tk_xtime(tk); | 1601 | |
1599 | *wtom = tk->wall_to_monotonic; | 1602 | ts = tk_xtime(tk); |
1600 | *sleep = tk->total_sleep_time; | 1603 | |
1604 | *offs_real = tk->offs_real; | ||
1605 | *offs_boot = tk->offs_boot; | ||
1606 | *offs_tai = tk->offs_tai; | ||
1601 | } while (read_seqcount_retry(&timekeeper_seq, seq)); | 1607 | } while (read_seqcount_retry(&timekeeper_seq, seq)); |
1608 | |||
1609 | now = ktime_set(ts.tv_sec, ts.tv_nsec); | ||
1610 | now = ktime_sub(now, *offs_real); | ||
1611 | return now; | ||
1602 | } | 1612 | } |
1603 | 1613 | ||
1604 | #ifdef CONFIG_HIGH_RES_TIMERS | 1614 | #ifdef CONFIG_HIGH_RES_TIMERS |
1605 | /** | 1615 | /** |
1606 | * ktime_get_update_offsets - hrtimer helper | 1616 | * ktime_get_update_offsets_now - hrtimer helper |
1607 | * @offs_real: pointer to storage for monotonic -> realtime offset | 1617 | * @offs_real: pointer to storage for monotonic -> realtime offset |
1608 | * @offs_boot: pointer to storage for monotonic -> boottime offset | 1618 | * @offs_boot: pointer to storage for monotonic -> boottime offset |
1609 | * @offs_tai: pointer to storage for monotonic -> clock tai offset | 1619 | * @offs_tai: pointer to storage for monotonic -> clock tai offset |
@@ -1611,7 +1621,7 @@ void get_xtime_and_monotonic_and_sleep_offset(struct timespec *xtim, | |||
1611 | * Returns current monotonic time and updates the offsets | 1621 | * Returns current monotonic time and updates the offsets |
1612 | * Called from hrtimer_interrupt() or retrigger_next_event() | 1622 | * Called from hrtimer_interrupt() or retrigger_next_event() |
1613 | */ | 1623 | */ |
1614 | ktime_t ktime_get_update_offsets(ktime_t *offs_real, ktime_t *offs_boot, | 1624 | ktime_t ktime_get_update_offsets_now(ktime_t *offs_real, ktime_t *offs_boot, |
1615 | ktime_t *offs_tai) | 1625 | ktime_t *offs_tai) |
1616 | { | 1626 | { |
1617 | struct timekeeper *tk = &timekeeper; | 1627 | struct timekeeper *tk = &timekeeper; |