diff options
author | Suresh Siddha <suresh.b.siddha@intel.com> | 2012-10-22 17:37:58 -0400 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2012-11-02 06:23:37 -0400 |
commit | 279f1461432ccdec0b98c0bcbe0a8e2c0f6fdda5 (patch) | |
tree | 1adaa912a846b6d45cff5c8b03db8f97d30ac779 /arch/x86/include/asm/msr-index.h | |
parent | 1e207eb1c3f0e8b690401f02fe08e7b53903f010 (diff) |
x86: apic: Use tsc deadline for oneshot when available
If the TSC deadline mode is supported, LAPIC timer one-shot mode can be
implemented using IA32_TSC_DEADLINE MSR. An interrupt will be generated
when the TSC value equals or exceeds the value in the IA32_TSC_DEADLINE
MSR.
This enables us to skip the APIC calibration during boot. Also, in
xapic mode, this enables us to skip the uncached apic access to re-arm
the APIC timer.
As this timer ticks at the high frequency TSC rate, we use the
TSC_DIVISOR (32) to work with the 32-bit restrictions in the
clockevent API's to avoid 64-bit divides etc (frequency is u32 and
"unsigned long" in the set_next_event(), max_delta limits the next
event to 32-bit for 32-bit kernel).
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Cc: venki@google.com
Cc: len.brown@intel.com
Link: http://lkml.kernel.org/r/1350941878.6017.31.camel@sbsiddha-desk.sc.intel.com
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'arch/x86/include/asm/msr-index.h')
-rw-r--r-- | arch/x86/include/asm/msr-index.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/x86/include/asm/msr-index.h b/arch/x86/include/asm/msr-index.h index 7f0edceb7563..e400cdb2dd65 100644 --- a/arch/x86/include/asm/msr-index.h +++ b/arch/x86/include/asm/msr-index.h | |||
@@ -337,6 +337,8 @@ | |||
337 | #define MSR_IA32_MISC_ENABLE_TURBO_DISABLE (1ULL << 38) | 337 | #define MSR_IA32_MISC_ENABLE_TURBO_DISABLE (1ULL << 38) |
338 | #define MSR_IA32_MISC_ENABLE_IP_PREF_DISABLE (1ULL << 39) | 338 | #define MSR_IA32_MISC_ENABLE_IP_PREF_DISABLE (1ULL << 39) |
339 | 339 | ||
340 | #define MSR_IA32_TSC_DEADLINE 0x000006E0 | ||
341 | |||
340 | /* P4/Xeon+ specific */ | 342 | /* P4/Xeon+ specific */ |
341 | #define MSR_IA32_MCG_EAX 0x00000180 | 343 | #define MSR_IA32_MCG_EAX 0x00000180 |
342 | #define MSR_IA32_MCG_EBX 0x00000181 | 344 | #define MSR_IA32_MCG_EBX 0x00000181 |