Skip to content
  • Vitaly Kuznetsov's avatar
    x86/hyperv: Move TSC reading method to asm/mshyperv.h · 0733379b
    Vitaly Kuznetsov authored
    
    
    As a preparation to making Hyper-V TSC page suitable for vDSO move
    the TSC page reading logic to asm/mshyperv.h. While on it, do the
    following:
    
    - Document the reading algorithm.
    - Simplify the code a bit.
    - Add explicit READ_ONCE() to not rely on 'volatile'.
    - Add explicit barriers to prevent re-ordering (we need to read sequence
      strictly before and after)
    - Use mul_u64_u64_shr() instead of assembly, gcc generates a single 'mul'
      instruction on x86_64 anyway.
    
    [ tglx: Simplified the loop ]
    
    Signed-off-by: default avatarVitaly Kuznetsov <vkuznets@redhat.com>
    Cc: Stephen Hemminger <sthemmin@microsoft.com>
    Cc: Haiyang Zhang <haiyangz@microsoft.com>
    Cc: Dexuan Cui <decui@microsoft.com>
    Cc: Andy Lutomirski <luto@amacapital.net>
    Cc: devel@linuxdriverproject.org
    Cc: "K. Y. Srinivasan" <kys@microsoft.com>
    Cc: virtualization@lists.linux-foundation.org
    Link: http://lkml.kernel.org/r/20170303132142.25595-3-vkuznets@redhat.com
    
    
    Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
    0733379b