Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch Move pmc.c into x86/, it can be shared with amd64.
details: https://anonhg.NetBSD.org/src/rev/1129a62c6487
branches: trunk
changeset: 352012:1129a62c6487
user: maxv <maxv%NetBSD.org@localhost>
date: Fri Mar 10 14:40:56 2017 +0000
description:
Move pmc.c into x86/, it can be shared with amd64.
diffstat:
sys/arch/amd64/include/pmc.h | 19 +-
sys/arch/i386/conf/files.i386 | 3 +-
sys/arch/i386/i386/pmc.c | 363 ------------------------------------------
sys/arch/x86/conf/files.x86 | 3 +-
sys/arch/x86/x86/pmc.c | 363 ++++++++++++++++++++++++++++++++++++++++++
sys/arch/xen/conf/files.xen | 4 +-
6 files changed, 376 insertions(+), 379 deletions(-)
diffs (truncated from 827 to 300 lines):
diff -r 7f46d42d7d97 -r 1129a62c6487 sys/arch/amd64/include/pmc.h
--- a/sys/arch/amd64/include/pmc.h Fri Mar 10 13:42:47 2017 +0000
+++ b/sys/arch/amd64/include/pmc.h Fri Mar 10 14:40:56 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pmc.h,v 1.3 2017/02/18 14:43:35 maxv Exp $ */
+/* $NetBSD: pmc.h,v 1.4 2017/03/10 14:40:56 maxv Exp $ */
/*-
* Copyright (c) 2000 Zembu Labs, Inc.
@@ -34,17 +34,14 @@
*/
#ifdef _KERNEL
-/*
- * LEGACY PMC support
- */
-struct x86_64_pmc_info_args;
-int pmc_info(struct proc *, struct x86_64_pmc_info_args *,
+struct x86_pmc_info_args;
+struct x86_pmc_startstop_args;
+struct x86_pmc_read_args;
+void pmc_init(void);
+int sys_pmc_info(struct lwp *, struct x86_pmc_info_args *,
register_t *);
-struct x86_64_pmc_startstop_args;
-int pmc_startstop(struct proc *, struct x86_64_pmc_startstop_args *,
+int sys_pmc_startstop(struct lwp *, struct x86_pmc_startstop_args *,
register_t *);
-struct x86_64_pmc_read_args;
-int pmc_read(struct proc *, struct x86_64_pmc_read_args *,
+int sys_pmc_read(struct lwp *, struct x86_pmc_read_args *,
register_t *);
-/* END LEGACY PMC SUPPORT */
#endif
diff -r 7f46d42d7d97 -r 1129a62c6487 sys/arch/i386/conf/files.i386
--- a/sys/arch/i386/conf/files.i386 Fri Mar 10 13:42:47 2017 +0000
+++ b/sys/arch/i386/conf/files.i386 Fri Mar 10 14:40:56 2017 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.i386,v 1.377 2017/02/17 12:10:40 maxv Exp $
+# $NetBSD: files.i386,v 1.378 2017/03/10 14:40:56 maxv Exp $
#
# new style config file for i386 architecture
#
@@ -74,7 +74,6 @@
file arch/i386/i386/machdep.c
file arch/i386/i386/longrun.c
file arch/i386/i386/mtrr_k6.c mtrr
-file arch/i386/i386/pmc.c
file arch/i386/i386/process_machdep.c
file arch/x86/x86/convert_xmm_s87.c
file arch/i386/i386/trap.c
diff -r 7f46d42d7d97 -r 1129a62c6487 sys/arch/i386/i386/pmc.c
--- a/sys/arch/i386/i386/pmc.c Fri Mar 10 13:42:47 2017 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,363 +0,0 @@
-/* $NetBSD: pmc.c,v 1.25 2017/03/10 13:09:11 maxv Exp $ */
-
-/*
- * Copyright (c) 2017 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Maxime Villard.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
- * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
- * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- * POSSIBILITY OF SUCH DAMAGE.
- */
-
-/*
- * Copyright (c) 2000 Zembu Labs, Inc.
- * All rights reserved.
- *
- * Author: Jason R. Thorpe <thorpej%zembu.com@localhost>
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- * must display the following acknowledgement:
- * This product includes software developed by Zembu Labs, Inc.
- * 4. Neither the name of Zembu Labs nor the names of its employees may
- * be used to endorse or promote products derived from this software
- * without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY ZEMBU LABS, INC. ``AS IS'' AND ANY EXPRESS
- * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WAR-
- * RANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DIS-
- * CLAIMED. IN NO EVENT SHALL ZEMBU LABS BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-/*
- * Interface to x86 CPU Performance Counters.
- */
-
-#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmc.c,v 1.25 2017/03/10 13:09:11 maxv Exp $");
-
-#include <sys/param.h>
-#include <sys/systm.h>
-#include <sys/proc.h>
-#include <sys/cpu.h>
-#include <sys/xcall.h>
-
-#include <machine/cpufunc.h>
-#include <machine/cpuvar.h>
-#include <machine/specialreg.h>
-#include <machine/sysarch.h>
-#include <machine/pmc.h>
-#include <machine/cpu_counter.h>
-#include <machine/cputypes.h>
-
-typedef struct {
- bool running;
- uint32_t evtmsr; /* event selector MSR */
- uint64_t evtval; /* event selector value */
- uint32_t ctrmsr; /* counter MSR */
- uint64_t ctrval; /* initial counter value */
-} pmc_state_t;
-
-static x86_pmc_cpuval_t pmc_val_cpus[MAXCPUS] __aligned(CACHE_LINE_SIZE);
-static kmutex_t pmc_lock;
-
-static pmc_state_t pmc_state[PMC_NCOUNTERS];
-static int pmc_ncounters __read_mostly;
-static int pmc_type __read_mostly;
-
-static void
-pmc_read_cpu(void *arg1, void *arg2)
-{
- pmc_state_t *pmc = (pmc_state_t *)arg1;
- struct cpu_info *ci = curcpu();
-
- pmc_val_cpus[cpu_index(ci)].ctrval =
- rdmsr(pmc->ctrmsr) & 0xffffffffffULL;
- pmc_val_cpus[cpu_index(ci)].overfl = 0;
-}
-
-static void
-pmc_read(pmc_state_t *pmc)
-{
- uint64_t xc;
-
- xc = xc_broadcast(0, pmc_read_cpu, pmc, NULL);
- xc_wait(xc);
-}
-
-static void
-pmc_apply_cpu(void *arg1, void *arg2)
-{
- pmc_state_t *pmc = (pmc_state_t *)arg1;
- struct cpu_info *ci = curcpu();
-
- wrmsr(pmc->ctrmsr, pmc->ctrval);
- switch (pmc_type) {
- case PMC_TYPE_I586:
- wrmsr(MSR_CESR, pmc_state[0].evtval |
- (pmc_state[1].evtval << 16));
- break;
-
- case PMC_TYPE_I686:
- case PMC_TYPE_K7:
- wrmsr(pmc->evtmsr, pmc->evtval);
- break;
- }
-
- pmc_val_cpus[cpu_index(ci)].ctrval = 0;
- pmc_val_cpus[cpu_index(ci)].overfl = 0;
-}
-
-static void
-pmc_apply(pmc_state_t *pmc)
-{
- uint64_t xc;
-
- xc = xc_broadcast(0, pmc_apply_cpu, pmc, NULL);
- xc_wait(xc);
-}
-
-static void
-pmc_start(pmc_state_t *pmc, struct x86_pmc_startstop_args *args)
-{
- uint64_t event, unit;
-
- pmc->running = true;
-
- /*
- * Initialize the counter MSR.
- */
- pmc->ctrval = args->val;
-
- /*
- * Initialize the event MSR.
- */
- switch (pmc_type) {
- case PMC_TYPE_I586:
- pmc->evtval = args->event |
- ((args->flags & PMC_SETUP_KERNEL) ? PMC5_CESR_OS : 0) |
- ((args->flags & PMC_SETUP_USER) ? PMC5_CESR_USR : 0) |
- ((args->flags & PMC_SETUP_EDGE) ? PMC5_CESR_E : 0);
- break;
-
- case PMC_TYPE_I686:
- pmc->evtval = args->event | PMC6_EVTSEL_EN |
- (args->unit << PMC6_EVTSEL_UNIT_SHIFT) |
- ((args->flags & PMC_SETUP_KERNEL) ? PMC6_EVTSEL_OS : 0) |
- ((args->flags & PMC_SETUP_USER) ? PMC6_EVTSEL_USR : 0) |
- ((args->flags & PMC_SETUP_EDGE) ? PMC6_EVTSEL_E : 0) |
- ((args->flags & PMC_SETUP_INV) ? PMC6_EVTSEL_INV : 0) |
- (args->compare << PMC6_EVTSEL_COUNTER_MASK_SHIFT);
- break;
-
- case PMC_TYPE_K7:
- event = (args->event & K7_EVTSEL_EVENT);
- unit = (args->unit << K7_EVTSEL_UNIT_SHIFT) &
- K7_EVTSEL_UNIT;
- pmc->evtval = event | unit | K7_EVTSEL_EN |
- ((args->flags & PMC_SETUP_KERNEL) ? K7_EVTSEL_OS : 0) |
- ((args->flags & PMC_SETUP_USER) ? K7_EVTSEL_USR : 0) |
- ((args->flags & PMC_SETUP_EDGE) ? K7_EVTSEL_E : 0) |
- ((args->flags & PMC_SETUP_INV) ? K7_EVTSEL_INV : 0) |
- (args->compare << K7_EVTSEL_COUNTER_MASK_SHIFT);
- break;
- }
-
- /*
- * Apply the changes.
- */
- pmc_apply(pmc);
-}
-
-static void
-pmc_stop(pmc_state_t *pmc, struct x86_pmc_startstop_args *args)
-{
- pmc->running = false;
- pmc->evtval = 0;
- pmc->ctrval = 0;
- pmc_apply(pmc);
-}
-
-void
-pmc_init(void)
-{
- const char *cpu_vendorstr;
- struct cpu_info *ci;
-
- pmc_type = PMC_TYPE_NONE;
-
- ci = curcpu();
- cpu_vendorstr = (char *)ci->ci_vendor;
-
- switch (cpu_class) {
- case CPUCLASS_586:
- if (strncmp(cpu_vendorstr, "GenuineIntel", 12) == 0) {
- pmc_type = PMC_TYPE_I586;
- pmc_ncounters = 2;
- pmc_state[0].ctrmsr = MSR_CTR0;
- pmc_state[1].ctrmsr = MSR_CTR1;
- break;
- }
-
- case CPUCLASS_686:
- if (strncmp(cpu_vendorstr, "GenuineIntel", 12) == 0) {
- /* Right now we're missing Pentium 4 support. */
- if (cpuid_level == -1 ||
- CPUID_TO_FAMILY(ci->ci_signature) == CPU_FAMILY_P4)
- break;
- pmc_type = PMC_TYPE_I686;
- pmc_ncounters = 2;
- pmc_state[0].evtmsr = MSR_EVNTSEL0;
- pmc_state[0].ctrmsr = MSR_PERFCTR0;
- pmc_state[1].evtmsr = MSR_EVNTSEL1;
Home |
Main Index |
Thread Index |
Old Index