Source-Changes-HG archive

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

[src/trunk]: src Add support for AMD Family 17h.



details:   https://anonhg.NetBSD.org/src/rev/b320a1b9f875
branches:  trunk
changeset: 456857:b320a1b9f875
user:      maxv <maxv%NetBSD.org@localhost>
date:      Wed May 29 17:09:17 2019 +0000

description:
Add support for AMD Family 17h.

diffstat:

 sys/dev/tprof/tprof_x86_amd.c   |   5 +-
 usr.sbin/tprof/arch/tprof_x86.c |  64 +++++++++++++++++++++++++++++++++++-----
 usr.sbin/tprof/tprof.8          |   8 +++-
 3 files changed, 64 insertions(+), 13 deletions(-)

diffs (149 lines):

diff -r 6cdaa3c7bd5f -r b320a1b9f875 sys/dev/tprof/tprof_x86_amd.c
--- a/sys/dev/tprof/tprof_x86_amd.c     Wed May 29 16:54:41 2019 +0000
+++ b/sys/dev/tprof/tprof_x86_amd.c     Wed May 29 17:09:17 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: tprof_x86_amd.c,v 1.2 2018/07/24 09:47:35 maxv Exp $   */
+/*     $NetBSD: tprof_x86_amd.c,v 1.3 2019/05/29 17:09:17 maxv Exp $   */
 
 /*
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -56,7 +56,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: tprof_x86_amd.c,v 1.2 2018/07/24 09:47:35 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: tprof_x86_amd.c,v 1.3 2019/05/29 17:09:17 maxv Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -205,6 +205,7 @@
 
        switch (CPUID_TO_FAMILY(ci->ci_signature)) {
        case 0x10:
+       case 0x17:
                return TPROF_IDENT_AMD_GENERIC;
        }
 
diff -r 6cdaa3c7bd5f -r b320a1b9f875 usr.sbin/tprof/arch/tprof_x86.c
--- a/usr.sbin/tprof/arch/tprof_x86.c   Wed May 29 16:54:41 2019 +0000
+++ b/usr.sbin/tprof/arch/tprof_x86.c   Wed May 29 17:09:17 2019 +0000
@@ -1,7 +1,7 @@
-/*     $NetBSD: tprof_x86.c,v 1.7 2018/11/26 23:20:57 knakahara Exp $  */
+/*     $NetBSD: tprof_x86.c,v 1.8 2019/05/29 17:09:18 maxv Exp $       */
 
 /*
- * Copyright (c) 2018 The NetBSD Foundation, Inc.
+ * Copyright (c) 2018-2019 The NetBSD Foundation, Inc.
  * All rights reserved.
  *
  * This code is derived from software contributed to The NetBSD Foundation
@@ -654,11 +654,57 @@
        .next = NULL
 };
 
-static struct event_table *
-init_amd_f10h(void)
-{
-       return &amd_f10h;
-}
+/*
+ * AMD Family 17h
+ */
+static struct name_to_event amd_f17h_names[] = {
+       { "FpRetx87FpOps",              0x02, __BITS(2,0), true },
+       { "FpRetSseAvxOps",             0x03, __BITS(7,0), true },
+       { "FpRetiredSerOps",            0x05, __BITS(3,0), true },
+       { "LsL1DTlbMiss",               0x45, __BITS(7,0), true },
+       { "LsTableWalker",              0x46, __BITS(3,0), true },
+       { "LsMisalAccesses",            0x47, 0x00, true },
+       { "LsInefSwPref",               0x52, __BITS(1,0), true },
+       { "LsNotHaltedCyc",             0x76, 0x00, true },
+       { "IcFw32",                     0x80, 0x00, true },
+       { "IcFw32Miss",                 0x81, 0x00, true },
+       { "IcCacheFillL2",              0x82, 0x00, true },
+       { "IcCacheFillSys",             0x83, 0x00, true },
+       { "IcFetchStall",               0x87, __BITS(2,0), true },
+       { "IcCacheInval",               0x8C, __BITS(1,0), true },
+       { "BpL1TlbMissL2Hit",           0x84, 0x00, true },
+       { "BpL1TlbMissL2Miss",          0x85, 0x00, true },
+       { "BpSnpReSync",                0x86, 0x00, true },
+       { "BpL1BTBCorrect",             0x8A, 0x00, true },
+       { "BpL2BTBCorrect",             0x8B, 0x00, true },
+       { "BpTlbRel",                   0x99, 0x00, true },
+       { "ExRetInstr",                 0xC0, 0x00, true },
+       { "ExRetCops",                  0xC1, 0x00, true },
+       { "ExRetBrn",                   0xC2, 0x00, true },
+       { "ExRetBrnMisp",               0xC3, 0x00, true },
+       { "ExRetBrnTkn",                0xC4, 0x00, true },
+       { "ExRetBrnTknMisp",            0xC5, 0x00, true },
+       { "ExRetBrnFar",                0xC6, 0x00, true },
+       { "ExRetBrnResync",             0xC7, 0x00, true },
+       { "ExRetBrnIndMisp",            0xCA, 0x00, true },
+       { "ExRetNearRet",               0xC8, 0x00, true },
+       { "ExRetNearRetMispred",        0xC9, 0x00, true },
+       { "ExRetMmxFpInstr@X87",        0xCB, __BIT(0), true },
+       { "ExRetMmxFpInstr@Mmx",        0xCB, __BIT(1), true },
+       { "ExRetMmxFpInstr@Sse",        0xCB, __BIT(2), true },
+       { "ExRetCond",                  0xD1, 0x00, true },
+       { "ExRetCondMisp",              0xD2, 0x00, true },
+       { "ExDivBusy",                  0xD3, 0x00, true },
+       { "ExDivCount",                 0xD4, 0x00, true },
+};
+
+static struct event_table amd_f17h = {
+       .tablename = "AMD Family 17h",
+       .names = amd_f17h_names,
+       .nevents = sizeof(amd_f17h_names) /
+           sizeof(struct name_to_event),
+       .next = NULL
+};
 
 static struct event_table *
 init_amd_generic(void)
@@ -673,7 +719,9 @@
 
        switch (CPUID_TO_FAMILY(eax)) {
        case 0x10:
-               return init_amd_f10h();
+               return &amd_f10h;
+       case 0x17:
+               return &amd_f17h;
        }
 
        return NULL;
diff -r 6cdaa3c7bd5f -r b320a1b9f875 usr.sbin/tprof/tprof.8
--- a/usr.sbin/tprof/tprof.8    Wed May 29 16:54:41 2019 +0000
+++ b/usr.sbin/tprof/tprof.8    Wed May 29 17:09:17 2019 +0000
@@ -1,4 +1,4 @@
-.\"    $NetBSD: tprof.8,v 1.13 2018/11/26 23:20:56 knakahara Exp $
+.\"    $NetBSD: tprof.8,v 1.14 2019/05/29 17:09:17 maxv Exp $
 .\"
 .\" Copyright (c)2011 YAMAMOTO Takashi,
 .\" All rights reserved.
@@ -24,7 +24,7 @@
 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 .\" SUCH DAMAGE.
 .\"
-.Dd November 27, 2018
+.Dd May 29, 2019
 .Dt TPROF 8
 .Os
 .Sh NAME
@@ -130,6 +130,8 @@
 .It
 x86 AMD Family 10h
 .It
+x86 AMD Family 17h
+.It
 x86 Intel Generic (all Intel CPUs)
 .It
 x86 Intel Skylake/Kabylake
@@ -168,7 +170,7 @@
 .An -nosplit
 The
 .Nm
-utility is written by
+utility was written by
 .An YAMAMOTO Takashi .
 It was revamped by
 .An Maxime Villard



Home | Main Index | Thread Index | Old Index