diff options
author | Marcelo Tosatti <mtosatti@redhat.com> | 2012-11-27 20:28:51 -0500 |
---|---|---|
committer | Marcelo Tosatti <mtosatti@redhat.com> | 2012-11-27 20:29:07 -0500 |
commit | dce2db0a35197e2f4421245079f19ab753e97348 (patch) | |
tree | c3151bef0ca980cf1c1af1fa6c4585df41e5a760 | |
parent | 42b5637d6989f75a7a0e8ea8633583564ff443ff (diff) |
x86: pvclock: create helper for pvclock data retrieval
Originally from Jeremy Fitzhardinge.
So code can be reused.
Acked-by: Glauber Costa <glommer@parallels.com>
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
-rw-r--r-- | arch/x86/include/asm/pvclock.h | 28 | ||||
-rw-r--r-- | arch/x86/kernel/pvclock.c | 16 |
2 files changed, 30 insertions, 14 deletions
diff --git a/arch/x86/include/asm/pvclock.h b/arch/x86/include/asm/pvclock.h index c59cc97fe6c1..47e25d464104 100644 --- a/arch/x86/include/asm/pvclock.h +++ b/arch/x86/include/asm/pvclock.h | |||
@@ -56,4 +56,32 @@ static inline u64 pvclock_scale_delta(u64 delta, u32 mul_frac, int shift) | |||
56 | return product; | 56 | return product; |
57 | } | 57 | } |
58 | 58 | ||
59 | static __always_inline | ||
60 | u64 pvclock_get_nsec_offset(const struct pvclock_vcpu_time_info *src) | ||
61 | { | ||
62 | u64 delta = __native_read_tsc() - src->tsc_timestamp; | ||
63 | return pvclock_scale_delta(delta, src->tsc_to_system_mul, | ||
64 | src->tsc_shift); | ||
65 | } | ||
66 | |||
67 | static __always_inline | ||
68 | unsigned __pvclock_read_cycles(const struct pvclock_vcpu_time_info *src, | ||
69 | cycle_t *cycles, u8 *flags) | ||
70 | { | ||
71 | unsigned version; | ||
72 | cycle_t ret, offset; | ||
73 | u8 ret_flags; | ||
74 | |||
75 | version = src->version; | ||
76 | rdtsc_barrier(); | ||
77 | offset = pvclock_get_nsec_offset(src); | ||
78 | ret = src->system_time + offset; | ||
79 | ret_flags = src->flags; | ||
80 | rdtsc_barrier(); | ||
81 | |||
82 | *cycles = ret; | ||
83 | *flags = ret_flags; | ||
84 | return version; | ||
85 | } | ||
86 | |||
59 | #endif /* _ASM_X86_PVCLOCK_H */ | 87 | #endif /* _ASM_X86_PVCLOCK_H */ |
diff --git a/arch/x86/kernel/pvclock.c b/arch/x86/kernel/pvclock.c index d59e60661794..a7d90910c61a 100644 --- a/arch/x86/kernel/pvclock.c +++ b/arch/x86/kernel/pvclock.c | |||
@@ -26,13 +26,6 @@ void pvclock_set_flags(u8 flags) | |||
26 | valid_flags = flags; | 26 | valid_flags = flags; |
27 | } | 27 | } |
28 | 28 | ||
29 | static u64 pvclock_get_nsec_offset(const struct pvclock_vcpu_time_info *src) | ||
30 | { | ||
31 | u64 delta = native_read_tsc() - src->tsc_timestamp; | ||
32 | return pvclock_scale_delta(delta, src->tsc_to_system_mul, | ||
33 | src->tsc_shift); | ||
34 | } | ||
35 | |||
36 | unsigned long pvclock_tsc_khz(struct pvclock_vcpu_time_info *src) | 29 | unsigned long pvclock_tsc_khz(struct pvclock_vcpu_time_info *src) |
37 | { | 30 | { |
38 | u64 pv_tsc_khz = 1000000ULL << 32; | 31 | u64 pv_tsc_khz = 1000000ULL << 32; |
@@ -55,17 +48,12 @@ void pvclock_resume(void) | |||
55 | cycle_t pvclock_clocksource_read(struct pvclock_vcpu_time_info *src) | 48 | cycle_t pvclock_clocksource_read(struct pvclock_vcpu_time_info *src) |
56 | { | 49 | { |
57 | unsigned version; | 50 | unsigned version; |
58 | cycle_t ret, offset; | 51 | cycle_t ret; |
59 | u64 last; | 52 | u64 last; |
60 | u8 flags; | 53 | u8 flags; |
61 | 54 | ||
62 | do { | 55 | do { |
63 | version = src->version; | 56 | version = __pvclock_read_cycles(src, &ret, &flags); |
64 | rdtsc_barrier(); | ||
65 | offset = pvclock_get_nsec_offset(src); | ||
66 | ret = src->system_time + offset; | ||
67 | flags = src->flags; | ||
68 | rdtsc_barrier(); | ||
69 | } while ((src->version & 1) || version != src->version); | 57 | } while ((src->version & 1) || version != src->version); |
70 | 58 | ||
71 | if ((valid_flags & PVCLOCK_TSC_STABLE_BIT) && | 59 | if ((valid_flags & PVCLOCK_TSC_STABLE_BIT) && |