Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/modules/tprof_pmi Move



details:   https://anonhg.NetBSD.org/src/rev/24ad10688957
branches:  trunk
changeset: 991504:24ad10688957
user:      maxv <maxv%NetBSD.org@localhost>
date:      Mon Jul 16 06:18:31 2018 +0000

description:
Move
        arch/x86/x86/tprof_pmi.c
        arch/x86/x86/tprof_amdpmi.c
into
        dev/tprof/tprof_x86_intel.c
        dev/tprof/tprof_x86_amd.c

diffstat:

 sys/arch/x86/conf/files.x86       |    5 +-
 sys/arch/x86/x86/tprof_amdpmi.c   |  272 --------------------------------------
 sys/arch/x86/x86/tprof_pmi.c      |  268 -------------------------------------
 sys/dev/tprof/tprof_x86_amd.c     |  272 ++++++++++++++++++++++++++++++++++++++
 sys/dev/tprof/tprof_x86_intel.c   |  268 +++++++++++++++++++++++++++++++++++++
 sys/modules/tprof_amdpmi/Makefile |    6 +-
 sys/modules/tprof_pmi/Makefile    |    6 +-
 7 files changed, 547 insertions(+), 550 deletions(-)

diffs (truncated from 1153 to 300 lines):

diff -r 91bb44e197d1 -r 24ad10688957 sys/arch/x86/conf/files.x86
--- a/sys/arch/x86/conf/files.x86       Mon Jul 16 02:36:39 2018 +0000
+++ b/sys/arch/x86/conf/files.x86       Mon Jul 16 06:18:31 2018 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: files.x86,v 1.102 2018/07/13 09:37:32 maxv Exp $
+#      $NetBSD: files.x86,v 1.103 2018/07/16 06:18:31 maxv Exp $
 
 # options for MP configuration through the MP spec
 defflag opt_mpbios.h MPBIOS MPDEBUG MPBIOS_SCANPCI
@@ -149,9 +149,6 @@
 
 file   arch/x86/x86/vga_post.c         vga_post
 
-file   arch/x86/x86/tprof_pmi.c        tprof_pmi
-file   arch/x86/x86/tprof_amdpmi.c     tprof_amdpmi
-
 file   arch/x86/pci/pci_machdep.c      pci
 #file  arch/x86/pci/pci_ranges.c       pci
 file   arch/x86/pci/pci_intr_machdep.c pci
diff -r 91bb44e197d1 -r 24ad10688957 sys/arch/x86/x86/tprof_amdpmi.c
--- a/sys/arch/x86/x86/tprof_amdpmi.c   Mon Jul 16 02:36:39 2018 +0000
+++ /dev/null   Thu Jan 01 00:00:00 1970 +0000
@@ -1,272 +0,0 @@
-/*     $NetBSD: tprof_amdpmi.c,v 1.9 2018/07/15 06:14:21 maxv Exp $    */
-
-/*
- * Copyright (c) 2018 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)2008,2009 YAMAMOTO Takashi,
- * All rights reserved.
- *
- * 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 AUTHOR 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 AUTHOR 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.
- */
-
-#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: tprof_amdpmi.c,v 1.9 2018/07/15 06:14:21 maxv Exp $");
-
-#include <sys/param.h>
-#include <sys/systm.h>
-#include <sys/kernel.h>
-#include <sys/module.h>
-
-#include <sys/cpu.h>
-#include <sys/xcall.h>
-
-#include <dev/tprof/tprof.h>
-
-#include <uvm/uvm.h>           /* VM_MIN_KERNEL_ADDRESS */
-
-#include <x86/nmi.h>
-
-#include <machine/cpufunc.h>
-#include <machine/cputypes.h>  /* CPUVENDOR_* */
-#include <machine/cpuvar.h>    /* cpu_vendor */
-#include <machine/i82489reg.h>
-#include <machine/i82489var.h>
-
-#define        NCTRS   4
-
-#define        PERFEVTSEL(i)           (0xc0010000 + (i))
-#define        PERFCTR(i)              (0xc0010004 + (i))
-
-#define        PESR_EVENT_MASK_LO      __BITS(0, 7)
-#define        PESR_UNIT_MASK          __BITS(8, 15)
-#define        PESR_USR                __BIT(16)
-#define        PESR_OS                 __BIT(17)
-#define        PESR_E                  __BIT(18)
-#define        PESR_PC                 __BIT(19)
-#define        PESR_INT                __BIT(20)
-                               /* bit 21 reserved */
-#define        PESR_EN                 __BIT(22)
-#define        PESR_INV                __BIT(23)
-#define        PESR_COUNTER_MASK       __BITS(24, 31)
-#define        PESR_EVENT_MASK_HI      __BITS(32, 35)
-                               /* bit 36-39 reserved */
-#define        PESR_GO                 __BIT(40)
-#define        PESR_HO                 __BIT(41)
-                               /* bit 42-63 reserved */
-
-/*
- * Documents:
- * http://support.amd.com/TechDocs/32559.pdf
- * http://developer.amd.com/wordpress/media/2012/10/Basic_Performance_Measurements.pdf
- */
-
-static int ctrno = 0;
-static uint64_t counter_val = 5000000;
-static uint64_t counter_reset_val;
-static uint32_t amd_lapic_saved[MAXCPUS];
-static nmi_handler_t *amd_nmi_handle;
-static tprof_param_t amd_param;
-
-static void
-tprof_amd_start_cpu(void *arg1, void *arg2)
-{
-       struct cpu_info * const ci = curcpu();
-       uint64_t pesr;
-       uint64_t event_lo;
-       uint64_t event_hi;
-
-       event_hi = amd_param.p_event >> 8;
-       event_lo = amd_param.p_event & 0xff;
-       pesr =
-           ((amd_param.p_flags & TPROF_PARAM_USER) ? PESR_USR : 0) |
-           ((amd_param.p_flags & TPROF_PARAM_KERN) ? PESR_OS : 0) |
-           PESR_INT |
-           __SHIFTIN(event_lo, PESR_EVENT_MASK_LO) |
-           __SHIFTIN(event_hi, PESR_EVENT_MASK_HI) |
-           __SHIFTIN(0, PESR_COUNTER_MASK) |
-           __SHIFTIN(amd_param.p_unit, PESR_UNIT_MASK);
-
-       wrmsr(PERFCTR(ctrno), counter_reset_val);
-       wrmsr(PERFEVTSEL(ctrno), pesr);
-
-       amd_lapic_saved[cpu_index(ci)] = lapic_readreg(LAPIC_PCINT);
-       lapic_writereg(LAPIC_PCINT, LAPIC_DLMODE_NMI);
-
-       wrmsr(PERFEVTSEL(ctrno), pesr | PESR_EN);
-}
-
-static void
-tprof_amd_stop_cpu(void *arg1, void *arg2)
-{
-       struct cpu_info * const ci = curcpu();
-
-       wrmsr(PERFEVTSEL(ctrno), 0);
-
-       lapic_writereg(LAPIC_PCINT, amd_lapic_saved[cpu_index(ci)]);
-}
-
-static int
-tprof_amd_nmi(const struct trapframe *tf, void *dummy)
-{
-       tprof_frame_info_t tfi;
-       uint64_t ctr;
-
-       KASSERT(dummy == NULL);
-
-       /* check if it's for us */
-       ctr = rdmsr(PERFCTR(ctrno));
-       if ((ctr & (UINT64_C(1) << 63)) != 0) { /* check if overflowed */
-               /* not ours */
-               return 0;
-       }
-
-       /* record a sample */
-#if defined(__x86_64__)
-       tfi.tfi_pc = tf->tf_rip;
-#else
-       tfi.tfi_pc = tf->tf_eip;
-#endif
-       tfi.tfi_inkernel = tfi.tfi_pc >= VM_MIN_KERNEL_ADDRESS;
-       tprof_sample(NULL, &tfi);
-
-       /* reset counter */
-       wrmsr(PERFCTR(ctrno), counter_reset_val);
-
-       return 1;
-}
-
-static uint64_t
-tprof_amd_estimate_freq(void)
-{
-       uint64_t cpufreq = curcpu()->ci_data.cpu_cc_freq;
-       uint64_t freq = 10000;
-
-       counter_val = cpufreq / freq;
-       if (counter_val == 0) {
-               counter_val = UINT64_C(4000000000) / freq;
-       }
-       return freq;
-}
-
-static uint32_t
-tprof_amd_ident(void)
-{
-       struct cpu_info *ci = curcpu();
-
-       if (cpu_vendor != CPUVENDOR_AMD) {
-               return TPROF_IDENT_NONE;
-       }
-
-       switch (CPUID_TO_FAMILY(ci->ci_signature)) {
-       case 0x10:
-               return TPROF_IDENT_AMD_GENERIC;
-       }
-
-       return TPROF_IDENT_NONE;
-}
-
-static int
-tprof_amd_start(const tprof_param_t *param)
-{
-       uint64_t xc;
-
-       if (tprof_amd_ident() == TPROF_IDENT_NONE) {
-               return ENOTSUP;
-       }
-
-       KASSERT(amd_nmi_handle == NULL);
-       amd_nmi_handle = nmi_establish(tprof_amd_nmi, NULL);
-
-       counter_reset_val = - counter_val + 1;
-       memcpy(&amd_param, param, sizeof(*param));
-
-       xc = xc_broadcast(0, tprof_amd_start_cpu, NULL, NULL);
-       xc_wait(xc);
-
-       return 0;
-}
-
-static void
-tprof_amd_stop(const tprof_param_t *param)
-{
-       uint64_t xc;
-
-       xc = xc_broadcast(0, tprof_amd_stop_cpu, NULL, NULL);
-       xc_wait(xc);
-
-       KASSERT(amd_nmi_handle != NULL);
-       nmi_disestablish(amd_nmi_handle);
-       amd_nmi_handle = NULL;
-}
-
-static const tprof_backend_ops_t tprof_amd_ops = {
-       .tbo_estimate_freq = tprof_amd_estimate_freq,
-       .tbo_ident = tprof_amd_ident,
-       .tbo_start = tprof_amd_start,
-       .tbo_stop = tprof_amd_stop,
-};
-
-MODULE(MODULE_CLASS_DRIVER, tprof_amdpmi, "tprof");
-
-static int
-tprof_amdpmi_modcmd(modcmd_t cmd, void *arg)
-{
-
-       switch (cmd) {
-       case MODULE_CMD_INIT:
-               return tprof_backend_register("tprof_amd", &tprof_amd_ops,
-                   TPROF_BACKEND_VERSION);
-
-       case MODULE_CMD_FINI:
-               return tprof_backend_unregister("tprof_amd");
-
-       default:
-               return ENOTTY;
-       }
-}
diff -r 91bb44e197d1 -r 24ad10688957 sys/arch/x86/x86/tprof_pmi.c
--- a/sys/arch/x86/x86/tprof_pmi.c      Mon Jul 16 02:36:39 2018 +0000
+++ /dev/null   Thu Jan 01 00:00:00 1970 +0000
@@ -1,268 +0,0 @@
-/*     $NetBSD: tprof_pmi.c,v 1.16 2018/07/15 06:14:21 maxv Exp $      */



Home | Main Index | Thread Index | Old Index