Venki Pallipadi 40fb17152c x86: support always running TSC on Intel CPUs
Impact: reward non-stop TSCs with good TSC-based clocksources, etc.

Add support for CPUID_0x80000007_Bit8 on Intel CPUs as well. This bit means
that the TSC is invariant with C/P/T states and always runs at constant
frequency.

With Intel CPUs, we have 3 classes
* CPUs where TSC runs at constant rate and does not stop n C-states
* CPUs where TSC runs at constant rate, but will stop in deep C-states
* CPUs where TSC rate will vary based on P/T-states and TSC will stop in deep
  C-states.

To cover these 3, one feature bit (CONSTANT_TSC) is not enough. So, add a
second bit (NONSTOP_TSC). CONSTANT_TSC indicates that the TSC runs at
constant frequency irrespective of P/T-states, and NONSTOP_TSC indicates
that TSC does not stop in deep C-states.

CPUID_0x8000000_Bit8 indicates both these feature bit can be set.
We still have CONSTANT_TSC _set_ and NONSTOP_TSC _not_set_ on some older Intel
CPUs, based on model checks. We can use TSC on such CPUs for time, as long as
those CPUs do not support/enter deep C-states.

Signed-off-by: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
2008-12-16 21:02:50 +01:00
..
2008-11-11 21:17:26 -05:00
2008-11-11 21:14:49 -05:00
2008-10-22 23:33:29 -04:00
2008-11-11 21:17:26 -05:00
2008-10-22 23:33:29 -04:00
2008-11-11 21:15:50 -05:00
2008-11-27 01:55:21 -05:00
2008-02-07 03:33:23 -05:00
2008-07-16 23:27:07 +02:00
2008-11-11 21:14:15 -05:00
2008-10-23 00:11:07 -04:00
2008-10-22 23:33:29 -04:00
2008-11-11 21:17:26 -05:00
2008-11-11 21:14:49 -05:00
2008-11-11 21:15:50 -05:00