Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src Add the AMD 10h family, with additional events that I believ...
details: https://anonhg.NetBSD.org/src/rev/1e16b710d0ec
branches: trunk
changeset: 352033:1e16b710d0ec
user: maxv <maxv%NetBSD.org@localhost>
date: Sat Mar 11 10:33:46 2017 +0000
description:
Add the AMD 10h family, with additional events that I believe are useful,
the DTLB misses on large pages for example.
While here, remove a few K7 flags that do not actually exist on K7 (there
must have been a confusion between K7 and K8); and make the 'pmc list'
command a little more user-friendly.
diffstat:
sys/arch/x86/include/specialreg.h | 103 +++++++-------------------
sys/arch/x86/x86/pmc.c | 58 +++++++++++---
usr.bin/pmc/pmc.c | 143 ++++++++++++++++++++++++-------------
3 files changed, 166 insertions(+), 138 deletions(-)
diffs (truncated from 481 to 300 lines):
diff -r 40a9885fb256 -r 1e16b710d0ec sys/arch/x86/include/specialreg.h
--- a/sys/arch/x86/include/specialreg.h Sat Mar 11 09:12:13 2017 +0000
+++ b/sys/arch/x86/include/specialreg.h Sat Mar 11 10:33:46 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: specialreg.h,v 1.94 2017/02/18 16:15:51 maxv Exp $ */
+/* $NetBSD: specialreg.h,v 1.95 2017/03/11 10:33:46 maxv Exp $ */
/*-
* Copyright (c) 1991 The Regents of the University of California.
@@ -997,94 +997,51 @@
#define PMC6_RET_SEG_RENAMES 0xd6 /* P-II and P-III only */
/*
- * AMD K7 Event Selector MSR format. [Doc: 22007K.pdf, Feb 2002]
+ * AMD K7. [Doc: 22007K.pdf, Feb 2002]
*/
-
+/* Event Selector MSR format */
#define K7_EVTSEL_EVENT 0x000000ff
#define K7_EVTSEL_UNIT 0x0000ff00
#define K7_EVTSEL_UNIT_SHIFT 8
-#define K7_EVTSEL_USR (1 << 16)
-#define K7_EVTSEL_OS (1 << 17)
-#define K7_EVTSEL_E (1 << 18)
-#define K7_EVTSEL_PC (1 << 19)
-#define K7_EVTSEL_INT (1 << 20)
-#define K7_EVTSEL_EN (1 << 22)
-#define K7_EVTSEL_INV (1 << 23)
+#define K7_EVTSEL_USR __BIT(16)
+#define K7_EVTSEL_OS __BIT(17)
+#define K7_EVTSEL_E __BIT(18)
+#define K7_EVTSEL_PC __BIT(19)
+#define K7_EVTSEL_INT __BIT(20)
+#define K7_EVTSEL_EN __BIT(22)
+#define K7_EVTSEL_INV __BIT(23)
#define K7_EVTSEL_COUNTER_MASK 0xff000000
#define K7_EVTSEL_COUNTER_MASK_SHIFT 24
-
-/* Segment Register Loads */
-#define K7_SEGMENT_REG_LOADS 0x20
-
-#define K7_STORES_TO_ACTIVE_INST_STREAM 0x21
-
/* Data Cache Unit */
#define K7_DATA_CACHE_ACCESS 0x40
#define K7_DATA_CACHE_MISS 0x41
#define K7_DATA_CACHE_REFILL 0x42
#define K7_DATA_CACHE_REFILL_SYSTEM 0x43
#define K7_DATA_CACHE_WBACK 0x44
-#define K7_L2_DTLB_HIT 0x45
+#define K7_L1_DTLB_MISS 0x45
#define K7_L2_DTLB_MISS 0x46
#define K7_MISALIGNED_DATA_REF 0x47
-#define K7_SYSTEM_REQUEST 0x64
-#define K7_SYSTEM_REQUEST_TYPE 0x65
-
-#define K7_SNOOP_HIT 0x73
-#define K7_SINGLE_BIT_ECC_ERROR 0x74
-#define K7_CACHE_LINE_INVAL 0x75
-#define K7_CYCLES_PROCESSOR_IS_RUNNING 0x76
-#define K7_L2_REQUEST 0x79
-#define K7_L2_REQUEST_BUSY 0x7a
-
/* Instruction Fetch Unit */
#define K7_IFU_IFETCH 0x80
#define K7_IFU_IFETCH_MISS 0x81
#define K7_IFU_REFILL_FROM_L2 0x82
#define K7_IFU_REFILL_FROM_SYSTEM 0x83
-#define K7_ITLB_L1_MISS 0x84
-#define K7_ITLB_L2_MISS 0x85
-#define K7_SNOOP_RESYNC 0x86
-#define K7_IFU_STALL 0x87
-
-#define K7_RETURN_STACK_HITS 0x88
-#define K7_RETURN_STACK_OVERFLOW 0x89
-
+#define K7_L1_ITLB_MISS 0x84
+#define K7_L2_ITLB_MISS 0x85
/* Retired */
#define K7_RETIRED_INST 0xc0
#define K7_RETIRED_OPS 0xc1
-#define K7_RETIRED_BRANCHES 0xc2
+#define K7_RETIRED_BRANCH 0xc2
#define K7_RETIRED_BRANCH_MISPREDICTED 0xc3
#define K7_RETIRED_TAKEN_BRANCH 0xc4
#define K7_RETIRED_TAKEN_BRANCH_MISPREDICTED 0xc5
#define K7_RETIRED_FAR_CONTROL_TRANSFER 0xc6
#define K7_RETIRED_RESYNC_BRANCH 0xc7
-#define K7_RETIRED_NEAR_RETURNS 0xc8
-#define K7_RETIRED_NEAR_RETURNS_MISPREDICTED 0xc9
-#define K7_RETIRED_INDIRECT_MISPREDICTED 0xca
-
/* Interrupts */
#define K7_CYCLES_INT_MASKED 0xcd
#define K7_CYCLES_INT_PENDING_AND_MASKED 0xce
#define K7_HW_INTR_RECV 0xcf
-#define K7_INSTRUCTION_DECODER_EMPTY 0xd0
-#define K7_DISPATCH_STALLS 0xd1
-#define K7_BRANCH_ABORTS_TO_RETIRE 0xd2
-#define K7_SERIALIZE 0xd3
-#define K7_SEGMENT_LOAD_STALL 0xd4
-#define K7_ICU_FULL 0xd5
-#define K7_RESERVATION_STATIONS_FULL 0xd6
-#define K7_FPU_FULL 0xd7
-#define K7_LS_FULL 0xd8
-#define K7_ALL_QUIET_STALL 0xd9
-#define K7_FAR_TRANSFER_OR_RESYNC_BRANCH_PENDING 0xda
-
-#define K7_BP0_MATCH 0xdc
-#define K7_BP1_MATCH 0xdd
-#define K7_BP2_MATCH 0xde
-#define K7_BP3_MATCH 0xdf
-
/*
* AMD 10h family PMCs. [Doc: 31116.pdf, Jan 2013]
*/
@@ -1132,14 +1089,14 @@
#define F10H_CANCELLED_STORE_LOAD_FORWARD_OPS 0x2A
#define F10H_SMI_RECEIVED 0x2B
/* Data Cache Events */
-#define F10H_DATA_CACHE_ACCESSES 0x40
-#define F10H_DATA_CACHE_MISSES 0x41
-#define F10H_DATA_CACHE_REFILLS_FROM_L2 0x42
-#define F10H_DATA_CACHE_REFILLS_FROM_NORTHBRIDGE 0x43
+#define F10H_DATA_CACHE_ACCESS 0x40
+#define F10H_DATA_CACHE_MISS 0x41
+#define F10H_DATA_CACHE_REFILL_FROM_L2 0x42
+#define F10H_DATA_CACHE_REFILL_FROM_NORTHBRIDGE 0x43
#define F10H_CACHE_LINES_EVICTED 0x44
#define F10H_L1_DTLB_MISS 0x45
#define F10H_L2_DTLB_MISS 0x46
-#define F10H_MISALIGNED_ACCESSES 0x47
+#define F10H_MISALIGNED_ACCESS 0x47
#define F10H_MICROARCH_LATE_CANCEL_OF_ACCESS 0x48
#define F10H_MICROARCH_EARLY_CANCEL_OF_ACCESS 0x49
#define F10H_SINGLE_BIT_ECC_ERRORS_RECORDED 0x4A
@@ -1160,10 +1117,10 @@
#define F10H_L2_FILL 0x7F
/* F10H_PAGE_SIZE_MISMATCHES (0x01C0): reserved on some revisions */
/* Instruction Cache Events */
-#define F10H_INSTRUCTION_CACHE_FETCHES 0x80
-#define F10H_INSTRUCTION_CACHE_MISSES 0x81
-#define F10H_INSTRUCTION_CACHE_REFILLS_FROM_L2 0x82
-#define F10H_INSTRUCTION_CACHE_REFILLS_FROM_SYS 0x83
+#define F10H_INSTRUCTION_CACHE_FETCH 0x80
+#define F10H_INSTRUCTION_CACHE_MISS 0x81
+#define F10H_INSTRUCTION_CACHE_REFILL_FROM_L2 0x82
+#define F10H_INSTRUCTION_CACHE_REFILL_FROM_SYS 0x83
#define F10H_L1_ITLB_MISS 0x84
#define F10H_L2_ITLB_MISS 0x85
#define F10H_PIPELINE_RESTART_INSTR_STREAM_PROBE 0x86
@@ -1177,15 +1134,15 @@
/* Execution Unit Events */
#define F10H_RETIRED_INSTRUCTIONS 0xC0
#define F10H_RETIRED_UOPS 0xC1
-#define F10H_RETIRED_BRANCH_INSTRUCTIONS 0xC2
-#define F10H_RETIRED_MISPREDICTED_BRANCH_INSTR 0xC3
-#define F10H_RETIRED_TAKEN_BRANCH_INSTRUCTIONS 0xC4
-#define F10H_RETIRED_TAKEN_BRANCH_INSTR_MISPREDICTED 0xC5
-#define F10H_RETIRED_FAR_CONTROL_TRANSFERS 0xC6
-#define F10H_RETIRED_BRANCH_RESYNCS 0xC7
+#define F10H_RETIRED_BRANCH 0xC2
+#define F10H_RETIRED_MISPREDICTED_BRANCH 0xC3
+#define F10H_RETIRED_TAKEN_BRANCH 0xC4
+#define F10H_RETIRED_TAKEN_BRANCH_MISPREDICTED 0xC5
+#define F10H_RETIRED_FAR_CONTROL_TRANSFER 0xC6
+#define F10H_RETIRED_BRANCH_RESYNC 0xC7
#define F10H_RETIRED_NEAR_RETURNS 0xC8
#define F10H_RETIRED_NEAR_RETURNS_MISPREDICTED 0xC9
-#define F10H_RETIRED_INDIRECT_BRANCHES_MISPREDICTED 0xCA
+#define F10H_RETIRED_INDIRECT_BRANCH_MISPREDICTED 0xCA
#define F10H_RETIRED_MMX_FP_INSTRUCTIONS 0xCB
#define F10H_RETIRED_FASTPATH_DOUBLE_OP_INSTR 0xCC
#define F10H_INTERRUPTS_MASKED_CYCLES 0xCD
diff -r 40a9885fb256 -r 1e16b710d0ec sys/arch/x86/x86/pmc.c
--- a/sys/arch/x86/x86/pmc.c Sat Mar 11 09:12:13 2017 +0000
+++ b/sys/arch/x86/x86/pmc.c Sat Mar 11 10:33:46 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pmc.c,v 1.1 2017/03/10 14:40:56 maxv Exp $ */
+/* $NetBSD: pmc.c,v 1.2 2017/03/11 10:33:46 maxv Exp $ */
/*
* Copyright (c) 2017 The NetBSD Foundation, Inc.
@@ -67,7 +67,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmc.c,v 1.1 2017/03/10 14:40:56 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmc.c,v 1.2 2017/03/11 10:33:46 maxv Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -133,6 +133,7 @@
case PMC_TYPE_I686:
case PMC_TYPE_K7:
+ case PMC_TYPE_F10H:
wrmsr(pmc->evtmsr, pmc->evtval);
break;
}
@@ -194,6 +195,22 @@
((args->flags & PMC_SETUP_INV) ? K7_EVTSEL_INV : 0) |
(args->compare << K7_EVTSEL_COUNTER_MASK_SHIFT);
break;
+
+ case PMC_TYPE_F10H:
+ event =
+ ((uint64_t)(args->event & 0x00FF) <<
+ F10H_EVTSEL_EVENT_SHIFT_LOW) |
+ ((uint64_t)(args->event & 0x0F00) <<
+ F10H_EVTSEL_EVENT_SHIFT_HIGH);
+ unit = (args->unit << F10H_EVTSEL_UNIT_SHIFT) &
+ F10H_EVTSEL_UNIT_MASK;
+ pmc->evtval = event | unit | F10H_EVTSEL_EN |
+ ((args->flags & PMC_SETUP_KERNEL) ? F10H_EVTSEL_OS : 0) |
+ ((args->flags & PMC_SETUP_USER) ? F10H_EVTSEL_USR : 0) |
+ ((args->flags & PMC_SETUP_EDGE) ? F10H_EVTSEL_EDGE : 0) |
+ ((args->flags & PMC_SETUP_INV) ? F10H_EVTSEL_INV : 0) |
+ (args->compare << F10H_EVTSEL_COUNTER_MASK_SHIFT);
+ break;
}
/*
@@ -245,17 +262,30 @@
pmc_state[1].evtmsr = MSR_EVNTSEL1;
pmc_state[1].ctrmsr = MSR_PERFCTR1;
} else if (strncmp(cpu_vendorstr, "AuthenticAMD", 12) == 0) {
- /* XXX: make sure it is at least K7 */
- pmc_type = PMC_TYPE_K7;
- pmc_ncounters = 4;
- pmc_state[0].evtmsr = MSR_K7_EVNTSEL0;
- pmc_state[0].ctrmsr = MSR_K7_PERFCTR0;
- pmc_state[1].evtmsr = MSR_K7_EVNTSEL1;
- pmc_state[1].ctrmsr = MSR_K7_PERFCTR1;
- pmc_state[2].evtmsr = MSR_K7_EVNTSEL2;
- pmc_state[2].ctrmsr = MSR_K7_PERFCTR2;
- pmc_state[3].evtmsr = MSR_K7_EVNTSEL3;
- pmc_state[3].ctrmsr = MSR_K7_PERFCTR3;
+ if (CPUID_TO_FAMILY(ci->ci_signature) == 0x10) {
+ pmc_type = PMC_TYPE_F10H;
+ pmc_ncounters = 4;
+ pmc_state[0].evtmsr = MSR_F10H_EVNTSEL0;
+ pmc_state[0].ctrmsr = MSR_F10H_PERFCTR0;
+ pmc_state[1].evtmsr = MSR_F10H_EVNTSEL1;
+ pmc_state[1].ctrmsr = MSR_F10H_PERFCTR1;
+ pmc_state[2].evtmsr = MSR_F10H_EVNTSEL2;
+ pmc_state[2].ctrmsr = MSR_F10H_PERFCTR2;
+ pmc_state[3].evtmsr = MSR_F10H_EVNTSEL3;
+ pmc_state[3].ctrmsr = MSR_F10H_PERFCTR3;
+ } else {
+ /* XXX: make sure it is at least K7 */
+ pmc_type = PMC_TYPE_K7;
+ pmc_ncounters = 4;
+ pmc_state[0].evtmsr = MSR_K7_EVNTSEL0;
+ pmc_state[0].ctrmsr = MSR_K7_PERFCTR0;
+ pmc_state[1].evtmsr = MSR_K7_EVNTSEL1;
+ pmc_state[1].ctrmsr = MSR_K7_PERFCTR1;
+ pmc_state[2].evtmsr = MSR_K7_EVNTSEL2;
+ pmc_state[2].ctrmsr = MSR_K7_PERFCTR2;
+ pmc_state[3].evtmsr = MSR_K7_EVNTSEL3;
+ pmc_state[3].ctrmsr = MSR_K7_PERFCTR3;
+ }
}
break;
}
@@ -268,6 +298,8 @@
{
struct x86_pmc_info_args rv;
+printf("PMCTYPE: %d\n", (int)pmc_type);
+
memset(&rv, 0, sizeof(rv));
rv.vers = PMC_VERSION;
diff -r 40a9885fb256 -r 1e16b710d0ec usr.bin/pmc/pmc.c
--- a/usr.bin/pmc/pmc.c Sat Mar 11 09:12:13 2017 +0000
+++ b/usr.bin/pmc/pmc.c Sat Mar 11 10:33:46 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pmc.c,v 1.21 2017/03/10 15:06:20 maxv Exp $ */
+/* $NetBSD: pmc.c,v 1.22 2017/03/11 10:33:46 maxv Exp $ */
/*
* Copyright (c) 2017 The NetBSD Foundation, Inc.
@@ -66,7 +66,7 @@
#include <sys/cdefs.h>
#ifndef lint
-__RCSID("$NetBSD: pmc.c,v 1.21 2017/03/10 15:06:20 maxv Exp $");
+__RCSID("$NetBSD: pmc.c,v 1.22 2017/03/11 10:33:46 maxv Exp $");
#endif
#include <inttypes.h>
@@ -275,15 +275,6 @@
};
static const pmc_name2val_t k7_names[] = {
- { "seg-load-all", K7_SEGMENT_REG_LOADS, 0x7f },
- { "seg-load-es", K7_SEGMENT_REG_LOADS, 0x01 },
- { "seg-load-cs", K7_SEGMENT_REG_LOADS, 0x02 },
Home |
Main Index |
Thread Index |
Old Index