Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/alpha On LCA45 systems, look at the memory controll...
details: https://anonhg.NetBSD.org/src/rev/e802d307887d
branches: trunk
changeset: 984685:e802d307887d
user: thorpej <thorpej%NetBSD.org@localhost>
date: Fri Jul 16 18:50:19 2021 +0000
description:
On LCA45 systems, look at the memory controller's Bcache configuration
to initialize uvmexp.ncolors rather than hard-coding a value per model
(some models can have more than one configuration).
diffstat:
sys/arch/alpha/alpha/dec_alphabook1.c | 6 ++-
sys/arch/alpha/alpha/dec_axppci_33.c | 14 ++--------
sys/arch/alpha/alpha/dec_eb66.c | 11 ++-----
sys/arch/alpha/pci/lca.c | 47 +++++++++++++++++++++++++++++++++-
sys/arch/alpha/pci/lcavar.h | 4 ++-
5 files changed, 58 insertions(+), 24 deletions(-)
diffs (221 lines):
diff -r 82969b7b442d -r e802d307887d sys/arch/alpha/alpha/dec_alphabook1.c
--- a/sys/arch/alpha/alpha/dec_alphabook1.c Fri Jul 16 17:09:33 2021 +0000
+++ b/sys/arch/alpha/alpha/dec_alphabook1.c Fri Jul 16 18:50:19 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dec_alphabook1.c,v 1.27 2012/10/13 17:58:54 jdc Exp $ */
+/* $NetBSD: dec_alphabook1.c,v 1.28 2021/07/16 18:50:19 thorpej Exp $ */
/*
* Copyright (c) 1995, 1996, 1997 Carnegie-Mellon University.
@@ -34,7 +34,7 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: dec_alphabook1.c,v 1.27 2012/10/13 17:58:54 jdc Exp $");
+__KERNEL_RCSID(0, "$NetBSD: dec_alphabook1.c,v 1.28 2021/07/16 18:50:19 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -107,6 +107,8 @@
platform.iobus = "lca";
platform.cons_init = dec_alphabook1_cons_init;
platform.device_register = dec_alphabook1_device_register;
+
+ lca_probe_bcache();
}
static void
diff -r 82969b7b442d -r e802d307887d sys/arch/alpha/alpha/dec_axppci_33.c
--- a/sys/arch/alpha/alpha/dec_axppci_33.c Fri Jul 16 17:09:33 2021 +0000
+++ b/sys/arch/alpha/alpha/dec_axppci_33.c Fri Jul 16 18:50:19 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dec_axppci_33.c,v 1.67 2012/10/13 17:58:54 jdc Exp $ */
+/* $NetBSD: dec_axppci_33.c,v 1.68 2021/07/16 18:50:19 thorpej Exp $ */
/*
* Copyright (c) 1995, 1996, 1997 Carnegie-Mellon University.
@@ -34,7 +34,7 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: dec_axppci_33.c,v 1.67 2012/10/13 17:58:54 jdc Exp $");
+__KERNEL_RCSID(0, "$NetBSD: dec_axppci_33.c,v 1.68 2021/07/16 18:50:19 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -43,8 +43,6 @@
#include <sys/conf.h>
#include <dev/cons.h>
-#include <uvm/uvm_extern.h>
-
#include <machine/rpb.h>
#include <machine/alpha.h>
#include <machine/autoconf.h>
@@ -156,13 +154,7 @@
/* Leave nsio mapped to catch any accidental port space collisions */
- /*
- * AXPpci33 systems have either 0, 256K, or 1M secondary
- * caches. Default to middle-of-the-road.
- *
- * XXX Dynamically size it!
- */
- uvmexp.ncolors = atop(256 * 1024);
+ lca_probe_bcache();
}
static void
diff -r 82969b7b442d -r e802d307887d sys/arch/alpha/alpha/dec_eb66.c
--- a/sys/arch/alpha/alpha/dec_eb66.c Fri Jul 16 17:09:33 2021 +0000
+++ b/sys/arch/alpha/alpha/dec_eb66.c Fri Jul 16 18:50:19 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dec_eb66.c,v 1.28 2012/10/13 17:58:54 jdc Exp $ */
+/* $NetBSD: dec_eb66.c,v 1.29 2021/07/16 18:50:19 thorpej Exp $ */
/*
* Copyright (c) 1995, 1996, 1997 Carnegie-Mellon University.
@@ -34,7 +34,7 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: dec_eb66.c,v 1.28 2012/10/13 17:58:54 jdc Exp $");
+__KERNEL_RCSID(0, "$NetBSD: dec_eb66.c,v 1.29 2021/07/16 18:50:19 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -43,8 +43,6 @@
#include <sys/conf.h>
#include <dev/cons.h>
-#include <uvm/uvm_extern.h>
-
#include <machine/rpb.h>
#include <machine/autoconf.h>
#include <machine/cpuconf.h>
@@ -110,10 +108,7 @@
platform.cons_init = dec_eb66_cons_init;
platform.device_register = dec_eb66_device_register;
- /*
- * EB66 systems have 1M secondary caches.
- */
- uvmexp.ncolors = atop(1 * 1024 * 1024);
+ lca_probe_bcache();
}
static void
diff -r 82969b7b442d -r e802d307887d sys/arch/alpha/pci/lca.c
--- a/sys/arch/alpha/pci/lca.c Fri Jul 16 17:09:33 2021 +0000
+++ b/sys/arch/alpha/pci/lca.c Fri Jul 16 18:50:19 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lca.c,v 1.55 2021/07/04 22:42:36 thorpej Exp $ */
+/* $NetBSD: lca.c,v 1.56 2021/07/16 18:50:19 thorpej Exp $ */
/*-
* Copyright (c) 2000 The NetBSD Foundation, Inc.
@@ -58,13 +58,15 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: lca.c,v 1.55 2021/07/04 22:42:36 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lca.c,v 1.56 2021/07/16 18:50:19 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/kernel.h>
#include <sys/device.h>
+#include <uvm/uvm_extern.h>
+
#include <machine/autoconf.h>
#include <machine/rpb.h>
#include <machine/sysarch.h>
@@ -92,6 +94,16 @@
struct lca_config lca_configuration;
static int lcafound;
+static const u_int lca_bcache_sizes[__SHIFTOUT(MEMC_CAR_BCS, MEMC_CAR_BCS)] = {
+[BCS_64K] = 64 * 1024,
+[BCS_128K] = 128 * 1024,
+[BCS_256K] = 256 * 1024,
+[BCS_512K] = 512 * 1024,
+[BCS_1M] = 1024 * 1024,
+[BCS_2M] = 2048 * 1024,
+/* Other values are reserved and we treat them as 0. */
+};
+
static int
lcamatch(device_t parent, cfdata_t match, void *aux)
{
@@ -108,6 +120,31 @@
}
/*
+ * Probe the memory controller's Bcache configuration.
+ */
+void
+lca_probe_bcache(void)
+{
+ const uint64_t car = REGVAL64(LCA_MEMC_CAR);
+
+ if (lca_configuration.lc_bcache_size != 0) {
+ /* Already done. */
+ return;
+ }
+
+ if (car & MEMC_CAR_BCE) {
+ lca_configuration.lc_bcache_size =
+ lca_bcache_sizes[__SHIFTOUT(car, MEMC_CAR_BCS)];
+ } else {
+ lca_configuration.lc_bcache_size = 0;
+ }
+
+ if (lca_configuration.lc_bcache_size) {
+ uvmexp.ncolors = atop(lca_configuration.lc_bcache_size);
+ }
+}
+
+/*
* Set up the chipset's function pointers.
*/
void
@@ -188,6 +225,12 @@
/* XXX print chipset information */
aprint_normal("\n");
+ if (lcp->lc_bcache_size != 0) {
+ char buf[sizeof("256 KB")];
+ if (format_bytes(buf, sizeof(buf), lcp->lc_bcache_size) > 0) {
+ aprint_normal_dev(self, "%s Bcache detected\n", buf);
+ }
+ }
lca_dma_init(lcp);
diff -r 82969b7b442d -r e802d307887d sys/arch/alpha/pci/lcavar.h
--- a/sys/arch/alpha/pci/lcavar.h Fri Jul 16 17:09:33 2021 +0000
+++ b/sys/arch/alpha/pci/lcavar.h Fri Jul 16 18:50:19 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lcavar.h,v 1.11 2012/02/06 02:14:14 matt Exp $ */
+/* $NetBSD: lcavar.h,v 1.12 2021/07/16 18:50:19 thorpej Exp $ */
/*
* Copyright (c) 1995, 1996 Carnegie-Mellon University.
@@ -52,6 +52,7 @@
struct extent *lc_io_ex, *lc_d_mem_ex, *lc_s_mem_ex;
int lc_mallocsafe;
+ u_int lc_bcache_size;
};
struct lca_softc {
@@ -60,6 +61,7 @@
struct lca_config *sc_lcp;
};
+void lca_probe_bcache(void);
void lca_init(struct lca_config *, int);
void lca_pci_init(pci_chipset_tag_t, void *);
void lca_dma_init(struct lca_config *);
Home |
Main Index |
Thread Index |
Old Index