summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>2003-09-25 22:13:20 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>2003-09-25 22:13:20 +0000
commita5f6b6516c356e445887fc2637220104789753e3 (patch)
tree91e28efdf28109ce6b54b26b135ad27f55b232d2 /sys
parent6e5e8b6a5cad91f86d5a028ba9b27b9650c742d9 (diff)
define pcxl2's mioc regs and devise l2 cache size on pcxl2 from there
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/hppa/dev/mem.c65
1 files changed, 58 insertions, 7 deletions
diff --git a/sys/arch/hppa/dev/mem.c b/sys/arch/hppa/dev/mem.c
index 7a5d3fa7b17..afe0a674d42 100644
--- a/sys/arch/hppa/dev/mem.c
+++ b/sys/arch/hppa/dev/mem.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mem.c,v 1.20 2003/04/07 20:18:34 mickey Exp $ */
+/* $OpenBSD: mem.c,v 1.21 2003/09/25 22:13:19 mickey Exp $ */
/*
* Copyright (c) 1998-2002 Michael Shalayeff
@@ -12,11 +12,6 @@
* 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 Michael Shalayeff.
- * 4. The name of the author may not be used to endorse or promote products
- * derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
@@ -100,10 +95,50 @@
#define VIPER_HPA 0xfffbf000
+/* registers on the PCXL2 MIOC */
+struct l2_mioc {
+ u_int32_t pad[0x20]; /* 0x000 */
+ u_int32_t mioc_control; /* 0x080 MIOC control bits */
+ u_int32_t mioc_status; /* 0x084 MIOC status bits */
+ u_int32_t pad1[6]; /* 0x088 */
+ u_int32_t sltcv; /* 0x0a0 L2 cache control */
+#define SLTCV_AVWL 0x00002000 /* extra cycle for addr valid write low */
+#define SLTCV_UP4COUT 0x00001000 /* update cache on CPU castouts */
+#define SLTCV_EDCEN 0x08000000 /* enable error correction */
+#define SLTCV_EDTAG 0x10000000 /* enable diagtag */
+#define SLTCV_CHKTP 0x20000000 /* enable parity checking */
+#define SLTCV_LOWPWR 0x40000000 /* low power mode */
+#define SLTCV_ENABLE 0x80000000 /* enable L2 cache */
+#define SLTCV_BITS "\020\15avwl\16up4cout\24edcen\25edtag\26chktp\27lowpwr\30l2ena"
+ u_int32_t tagmask; /* 0x0a4 L2 cache tag mask */
+ u_int32_t diagtag; /* 0x0a8 L2 invalidates tag */
+ u_int32_t sltestat; /* 0x0ac L2 last logged tag read */
+ u_int32_t slteadd; /* 0x0b0 L2 pa of -- " -- */
+ u_int32_t pad2[3]; /* 0x0b4 */
+ u_int32_t mtcv; /* 0x0c0 MIOC timings */
+ u_int32_t ref; /* 0x0cc MIOC refresh timings */
+ u_int32_t pad3[4]; /* 0x0d0 */
+ u_int32_t mderradd; /* 0x0e0 addr of most evil mem error */
+ u_int32_t pad4; /* 0x0e4 */
+ u_int32_t dmaerr; /* 0x0e8 addr of most evil dma error */
+ u_int32_t dioerr; /* 0x0ec addr of most evil dio error */
+ u_int32_t gsc_timeout; /* 0x0f0 1-compl of GSC timeout delay */
+ u_int32_t hidmamem; /* 0x0f4 amount of phys mem installed */
+ u_int32_t pad5[2]; /* 0x0f8 */
+ u_int32_t memcomp[16]; /* 0x100 memory address comparators */
+ u_int32_t memmask[16]; /* 0x140 masks for -- " -- */
+ u_int32_t memtest; /* 0x180 test address decoding */
+ u_int32_t pad6[0xf]; /* 0x184 */
+ u_int32_t outchk; /* 0x1c0 address decoding output */
+ u_int32_t pad7[0x168]; /* 0x200 */
+ u_int32_t gsc15x_config; /* 0x7a0 writev enable */
+};
+
struct mem_softc {
struct device sc_dev;
volatile struct vi_trs *sc_vp;
+ volatile struct l2_mioc *sc_l2;
};
int memmatch(struct device *, void *, void *);
@@ -187,7 +222,23 @@ memattach(parent, self, aux)
printf(" size %d", pdc_minit.max_spa / (1024*1024));
if (pdc_minit.max_spa % (1024*1024))
printf(".%d", pdc_minit.max_spa % (1024*1024));
- printf("MB\n");
+ printf("MB");
+
+ /* L2 cache controller is a part of the memory controller on PCXL2 */
+ if (cpu_type == hpcxl2) {
+ sc->sc_l2 = (struct l2_mioc *)ca->ca_hpa;
+#ifdef DEBUG
+ printf(", sltcv %b", sc->sc_l2->sltcv, SLTCV_BITS);
+#endif
+ /* sc->sc_l2->sltcv |= SLTCV_UP4COUT; */
+ if (sc->sc_l2->sltcv & SLTCV_ENABLE) {
+ u_int32_t tagmask = sc->sc_l2->tagmask >> 20;
+
+ printf(", %dMB L2 cache", tagmask + 1);
+ }
+ }
+
+ printf("\n");
}
void