diff options
Diffstat (limited to 'arch/x86/kernel/tsc.c')
| -rw-r--r-- | arch/x86/kernel/tsc.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/arch/x86/kernel/tsc.c b/arch/x86/kernel/tsc.c index d57de05dc430..cf8611d991e0 100644 --- a/arch/x86/kernel/tsc.c +++ b/arch/x86/kernel/tsc.c | |||
| @@ -710,7 +710,16 @@ static cycle_t read_tsc(struct clocksource *cs) | |||
| 710 | #ifdef CONFIG_X86_64 | 710 | #ifdef CONFIG_X86_64 |
| 711 | static cycle_t __vsyscall_fn vread_tsc(void) | 711 | static cycle_t __vsyscall_fn vread_tsc(void) |
| 712 | { | 712 | { |
| 713 | cycle_t ret = (cycle_t)vget_cycles(); | 713 | cycle_t ret; |
| 714 | |||
| 715 | /* | ||
| 716 | * Surround the RDTSC by barriers, to make sure it's not | ||
| 717 | * speculated to outside the seqlock critical section and | ||
| 718 | * does not cause time warps: | ||
| 719 | */ | ||
| 720 | rdtsc_barrier(); | ||
| 721 | ret = (cycle_t)vget_cycles(); | ||
| 722 | rdtsc_barrier(); | ||
| 714 | 723 | ||
| 715 | return ret >= __vsyscall_gtod_data.clock.cycle_last ? | 724 | return ret >= __vsyscall_gtod_data.clock.cycle_last ? |
| 716 | ret : __vsyscall_gtod_data.clock.cycle_last; | 725 | ret : __vsyscall_gtod_data.clock.cycle_last; |
