Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/x86 Make new function named tsc_is_invariant() to a...
details: https://anonhg.NetBSD.org/src/rev/1eb652e7a217
branches: trunk
changeset: 325192:1eb652e7a217
user: msaitoh <msaitoh%NetBSD.org@localhost>
date: Wed Dec 11 02:14:08 2013 +0000
description:
Make new function named tsc_is_invariant() to avoid code duplication.
The behavior of acpicpu_md_flags() will change on some CPUs because
the detecting code of invariant TSC is replaced with newer code.
diffstat:
sys/arch/x86/acpi/acpi_cpu_md.c | 42 +++++++++++++++-------------------------
sys/arch/x86/x86/tsc.c | 34 +++++++++++++++++++++++---------
sys/arch/x86/x86/tsc.h | 3 +-
3 files changed, 42 insertions(+), 37 deletions(-)
diffs (173 lines):
diff -r 4e28678febe5 -r 1eb652e7a217 sys/arch/x86/acpi/acpi_cpu_md.c
--- a/sys/arch/x86/acpi/acpi_cpu_md.c Wed Dec 11 01:29:29 2013 +0000
+++ b/sys/arch/x86/acpi/acpi_cpu_md.c Wed Dec 11 02:14:08 2013 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_cpu_md.c,v 1.74 2013/11/20 13:52:30 jruoho Exp $ */
+/* $NetBSD: acpi_cpu_md.c,v 1.75 2013/12/11 02:14:08 msaitoh Exp $ */
/*-
* Copyright (c) 2010, 2011 Jukka Ruohonen <jruohonen%iki.fi@localhost>
@@ -27,7 +27,7 @@
* SUCH DAMAGE.
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_cpu_md.c,v 1.74 2013/11/20 13:52:30 jruoho Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_cpu_md.c,v 1.75 2013/12/11 02:14:08 msaitoh Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -43,6 +43,7 @@
#include <x86/cpuvar.h>
#include <x86/cpu_msr.h>
#include <x86/machdep.h>
+#include <x86/x86/tsc.h>
#include <dev/acpi/acpica.h>
#include <dev/acpi/acpi_cpu.h>
@@ -162,6 +163,16 @@
*/
val |= ACPICPU_FLAG_C_APIC | ACPICPU_FLAG_C_TSC;
+ /*
+ * Detect whether TSC is invariant. If it is not, we keep the flag to
+ * note that TSC will not run at constant rate. Depending on the CPU,
+ * this may affect P- and T-state changes, but especially relevant
+ * are C-states; with variant TSC, states larger than C1 may
+ * completely stop the counter.
+ */
+ if (tsc_is_invariant())
+ val &= ~ACPICPU_FLAG_C_TSC;
+
switch (cpu_vendor) {
case CPUVENDOR_IDT:
@@ -214,24 +225,6 @@
val &= ~ACPICPU_FLAG_C_APIC;
}
- /*
- * Detect whether TSC is invariant. If it is not,
- * we keep the flag to note that TSC will not run
- * at constant rate. Depending on the CPU, this may
- * affect P- and T-state changes, but especially
- * relevant are C-states; with variant TSC, states
- * larger than C1 may completely stop the counter.
- */
- x86_cpuid(0x80000000, regs);
-
- if (regs[0] >= 0x80000007) {
-
- x86_cpuid(0x80000007, regs);
-
- if ((regs[3] & __BIT(8)) != 0)
- val &= ~ACPICPU_FLAG_C_TSC;
- }
-
break;
case CPUVENDOR_AMD:
@@ -284,13 +277,10 @@
case 0x15: /* AMD Bulldozer */
/*
- * Like with Intel, detect invariant TSC,
- * MSR-based P-states, and AMD's "turbo"
- * (Core Performance Boost), respectively.
+ * Like with Intel, detect MSR-based P-states,
+ * and AMD's "turbo" (Core Performance Boost),
+ * respectively.
*/
- if ((regs[3] & CPUID_APM_TSC) != 0)
- val &= ~ACPICPU_FLAG_C_TSC;
-
if ((regs[3] & CPUID_APM_HWP) != 0)
val |= ACPICPU_FLAG_P_FFH;
diff -r 4e28678febe5 -r 1eb652e7a217 sys/arch/x86/x86/tsc.c
--- a/sys/arch/x86/x86/tsc.c Wed Dec 11 01:29:29 2013 +0000
+++ b/sys/arch/x86/x86/tsc.c Wed Dec 11 02:14:08 2013 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tsc.c,v 1.34 2013/12/08 04:07:38 msaitoh Exp $ */
+/* $NetBSD: tsc.c,v 1.35 2013/12/11 02:14:08 msaitoh Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: tsc.c,v 1.34 2013/12/08 04:07:38 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: tsc.c,v 1.35 2013/12/11 02:14:08 msaitoh Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -63,23 +63,19 @@
.tc_quality = 3000,
};
-void
-tsc_tc_init(void)
+bool
+tsc_is_invariant(void)
{
struct cpu_info *ci;
uint32_t descs[4];
uint32_t family;
bool invariant;
- if (!cpu_hascounter()) {
- return;
- }
+ if (!cpu_hascounter())
+ return false;
ci = curcpu();
invariant = false;
- tsc_freq = ci->ci_data.cpu_cc_freq;
- tsc_good = (cpu_feature[0] & CPUID_MSR) != 0 &&
- (rdmsr(MSR_TSC) != 0 || rdmsr(MSR_TSC) != 0);
if (cpu_vendor == CPUVENDOR_INTEL) {
/*
@@ -140,6 +136,24 @@
}
}
+ return invariant;
+}
+
+void
+tsc_tc_init(void)
+{
+ struct cpu_info *ci;
+ bool invariant;
+
+ if (!cpu_hascounter())
+ return;
+
+ ci = curcpu();
+ tsc_freq = ci->ci_data.cpu_cc_freq;
+ tsc_good = (cpu_feature[0] & CPUID_MSR) != 0 &&
+ (rdmsr(MSR_TSC) != 0 || rdmsr(MSR_TSC) != 0);
+
+ invariant = tsc_is_invariant();
if (!invariant) {
aprint_debug("TSC not known invariant on this CPU\n");
tsc_timecounter.tc_quality = -100;
diff -r 4e28678febe5 -r 1eb652e7a217 sys/arch/x86/x86/tsc.h
--- a/sys/arch/x86/x86/tsc.h Wed Dec 11 01:29:29 2013 +0000
+++ b/sys/arch/x86/x86/tsc.h Wed Dec 11 02:14:08 2013 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tsc.h,v 1.4 2008/05/10 16:12:32 ad Exp $ */
+/* $NetBSD: tsc.h,v 1.5 2013/12/11 02:14:08 msaitoh Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -26,6 +26,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
+bool tsc_is_invariant(void);
void tsc_tc_init(void);
void tsc_sync_ap(struct cpu_info *);
void tsc_sync_bp(struct cpu_info *);
Home |
Main Index |
Thread Index |
Old Index