Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/cpuctl/arch show clidr_el1 and ctr_el0.
details: https://anonhg.NetBSD.org/src/rev/4159967d0be1
branches: trunk
changeset: 1011486:4159967d0be1
user: ryo <ryo%NetBSD.org@localhost>
date: Wed Jul 01 08:03:10 2020 +0000
description:
show clidr_el1 and ctr_el0.
diffstat:
usr.sbin/cpuctl/arch/aarch64.c | 145 +++++++++++++++++++++++++++++++++++++---
1 files changed, 133 insertions(+), 12 deletions(-)
diffs (207 lines):
diff -r 1ee7b633d911 -r 4159967d0be1 usr.sbin/cpuctl/arch/aarch64.c
--- a/usr.sbin/cpuctl/arch/aarch64.c Wed Jul 01 08:02:13 2020 +0000
+++ b/usr.sbin/cpuctl/arch/aarch64.c Wed Jul 01 08:03:10 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: aarch64.c,v 1.9 2020/05/10 21:42:05 riastradh Exp $ */
+/* $NetBSD: aarch64.c,v 1.10 2020/07/01 08:03:10 ryo Exp $ */
/*
* Copyright (c) 2018 Ryo Shimizu <ryo%nerv.org@localhost>
@@ -29,7 +29,7 @@
#include <sys/cdefs.h>
#ifndef lint
-__RCSID("$NetBSD: aarch64.c,v 1.9 2020/05/10 21:42:05 riastradh Exp $");
+__RCSID("$NetBSD: aarch64.c,v 1.10 2020/07/01 08:03:10 ryo Exp $");
#endif /* no lint */
#include <sys/types.h>
@@ -60,8 +60,11 @@
};
struct fieldinfo {
- int bitpos;
- int bitwidth;
+ unsigned int flags;
+#define FIELDINFO_FLAGS_DEC 0x0001
+#define FIELDINFO_FLAGS_4LOG2 0x0002
+ unsigned char bitpos;
+ unsigned char bitwidth;
const char *name;
const char * const *info;
};
@@ -549,13 +552,108 @@
{ .bitwidth = 0 } /* end of table */
};
+/* CLIDR_EL1 - Cache Level ID Register */
+const char * const clidr_cachetype[8] = { /* 8=3bit */
+ [0] = "None",
+ [1] = "Instruction cache",
+ [2] = "Data cache",
+ [3] = "Instruction and Data cache",
+ [4] = "Unified cache"
+};
+
+struct fieldinfo clidr_fieldinfo[] = {
+ {
+ .bitpos = 0, .bitwidth = 3, .name = "L1",
+ .info = clidr_cachetype
+ },
+ {
+ .bitpos = 3, .bitwidth = 3, .name = "L2",
+ .info = clidr_cachetype
+ },
+ {
+ .bitpos = 6, .bitwidth = 3, .name = "L3",
+ .info = clidr_cachetype
+ },
+ {
+ .bitpos = 9, .bitwidth = 3, .name = "L4",
+ .info = clidr_cachetype
+ },
+ {
+ .bitpos = 12, .bitwidth = 3, .name = "L5",
+ .info = clidr_cachetype
+ },
+ {
+ .bitpos = 15, .bitwidth = 3, .name = "L6",
+ .info = clidr_cachetype
+ },
+ {
+ .bitpos = 18, .bitwidth = 3, .name = "L7",
+ .info = clidr_cachetype
+ },
+ {
+ .bitpos = 21, .bitwidth = 3, .name = "LoUU",
+ .flags = FIELDINFO_FLAGS_DEC
+ },
+ {
+ .bitpos = 24, .bitwidth = 3, .name = "LoC",
+ .flags = FIELDINFO_FLAGS_DEC
+ },
+ {
+ .bitpos = 27, .bitwidth = 3, .name = "LoUIS",
+ .flags = FIELDINFO_FLAGS_DEC
+ },
+ {
+ .bitpos = 30, .bitwidth = 3, .name = "ICB",
+ .flags = FIELDINFO_FLAGS_DEC
+ },
+ { .bitwidth = 0 } /* end of table */
+};
+
+struct fieldinfo ctr_fieldinfo[] = {
+ {
+ .bitpos = 0, .bitwidth = 4, .name = "IminLine",
+ .flags = FIELDINFO_FLAGS_DEC | FIELDINFO_FLAGS_4LOG2
+ },
+ {
+ .bitpos = 16, .bitwidth = 4, .name = "DminLine",
+ .flags = FIELDINFO_FLAGS_DEC | FIELDINFO_FLAGS_4LOG2
+ },
+ {
+ .bitpos = 14, .bitwidth = 2, .name = "L1 Icache policy",
+ .info = (const char *[4]) { /* 4=2bit */
+ [0] = "VMID aware PIPT (VPIPT)",
+ [1] = "ASID-tagged VIVT (AIVIVT)",
+ [2] = "VIPT",
+ [3] = "PIPT"
+ },
+ },
+ {
+ .bitpos = 20, .bitwidth = 4, .name = "ERG",
+ .flags = FIELDINFO_FLAGS_DEC | FIELDINFO_FLAGS_4LOG2
+ },
+ {
+ .bitpos = 24, .bitwidth = 4, .name = "CWG",
+ .flags = FIELDINFO_FLAGS_DEC | FIELDINFO_FLAGS_4LOG2
+ },
+ {
+ .bitpos = 28, .bitwidth = 1, .name = "DIC",
+ .flags = FIELDINFO_FLAGS_DEC
+ },
+ {
+ .bitpos = 29, .bitwidth = 1, .name = "IDC",
+ .flags = FIELDINFO_FLAGS_DEC
+ },
+ { .bitwidth = 0 } /* end of table */
+};
+
+
static void
print_fieldinfo(const char *cpuname, const char *setname,
struct fieldinfo *fieldinfo, uint64_t data)
{
uint64_t v;
const char *info;
- int i;
+ int i, flags;
#define WIDTHMASK(w) (0xffffffffffffffffULL >> (64 - (w)))
@@ -563,13 +661,24 @@
v = (data >> fieldinfo[i].bitpos) &
WIDTHMASK(fieldinfo[i].bitwidth);
- info = fieldinfo[i].info[v];
- if (info == NULL)
- printf("%s: %s: %s: 0x%"PRIx64"\n",
- cpuname, setname, fieldinfo[i].name, v);
- else
- printf("%s: %s: %s: %s\n",
- cpuname, setname, fieldinfo[i].name, info);
+ flags = fieldinfo[i].flags;
+ info = NULL;
+ if (fieldinfo[i].info != NULL)
+ info = fieldinfo[i].info[v];
+
+ printf("%s: %s: %s: ",
+ cpuname, setname, fieldinfo[i].name);
+
+ if (info == NULL) {
+ if (flags & FIELDINFO_FLAGS_4LOG2)
+ v = 4 * (1 << v);
+ if (flags & FIELDINFO_FLAGS_DEC)
+ printf("%"PRIu64"\n", v);
+ else
+ printf("0x%"PRIx64"\n", v);
+ } else {
+ printf("%s\n", info);
+ }
}
}
@@ -671,6 +780,7 @@
snprintf(path, sizeof path, "machdep.%s.cpu_id", cpuname);
len = sizeof(sysctlbuf);
+ memset(sysctlbuf, 0, len);
if (sysctlbyname(path, id, &len, 0, 0) == -1)
err(1, "couldn't get %s", path);
if (len != sizeof(struct aarch64_sysctl_cpu_id))
@@ -707,6 +817,10 @@
cpuname, id->ac_mvfr1);
printf("%s: MVFR2_EL1: 0x%08"PRIx32"\n",
cpuname, id->ac_mvfr2);
+ printf("%s: CLIDR_EL1: 0x%016"PRIx64"\n",
+ cpuname, id->ac_clidr);
+ printf("%s: CTR_EL0: 0x%016"PRIx64"\n",
+ cpuname, id->ac_ctr);
}
identify_midr(cpuname, id->ac_midr);
@@ -730,6 +844,13 @@
mvfr1_fieldinfo, id->ac_mvfr1);
print_fieldinfo(cpuname, "media and VFP features 2",
mvfr2_fieldinfo, id->ac_mvfr2);
+
+ if (len <= offsetof(struct aarch64_sysctl_cpu_id, ac_clidr))
+ return;
+ print_fieldinfo(cpuname, "cache level",
+ clidr_fieldinfo, id->ac_clidr);
+ print_fieldinfo(cpuname, "cache type",
+ ctr_fieldinfo, id->ac_ctr);
}
bool
Home |
Main Index |
Thread Index |
Old Index