summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2005-12-12 20:36:34 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2005-12-12 20:36:34 +0000
commit1f8007eb44b203c130b154b255878a842721d381 (patch)
tree75f76d85d0e40f9de98dc70e6ebb26beb05148d6 /sys/arch
parentf0cfa38ae02bc020a72577cf17fb5d3fcb8fd943 (diff)
Move the MC88410 support code to a specific .c function instead of heavy
(and large) inlines. While there, provide correct register clobbering information to the __asm__ statements, and fix mc88410_flush_page() evil typo. Finally, rework mc88410_inval() busy-wait logic to behave correctly in all cases.
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/mvme88k/conf/files.mvme88k3
-rw-r--r--sys/arch/mvme88k/include/m88410.h129
-rw-r--r--sys/arch/mvme88k/mvme88k/m88410.c154
3 files changed, 162 insertions, 124 deletions
diff --git a/sys/arch/mvme88k/conf/files.mvme88k b/sys/arch/mvme88k/conf/files.mvme88k
index 2200033a696..3e5f5aff3ed 100644
--- a/sys/arch/mvme88k/conf/files.mvme88k
+++ b/sys/arch/mvme88k/conf/files.mvme88k
@@ -1,4 +1,4 @@
-# $OpenBSD: files.mvme88k,v 1.38 2005/10/24 19:28:29 miod Exp $
+# $OpenBSD: files.mvme88k,v 1.39 2005/12/12 20:36:30 miod Exp $
#
maxpartitions 16
@@ -82,6 +82,7 @@ file arch/mvme88k/mvme88k/m188_machdep.c mvme188
file arch/mvme88k/mvme88k/m197_machdep.c mvme197
file arch/mvme88k/mvme88k/m88110.c m88110
file arch/mvme88k/mvme88k/m8820x.c m88100
+file arch/mvme88k/mvme88k/m88410.c m88110
file arch/mvme88k/mvme88k/mem.c
file arch/mvme88k/mvme88k/pmap_bootstrap.c
file arch/mvme88k/mvme88k/pmap_table.c
diff --git a/sys/arch/mvme88k/include/m88410.h b/sys/arch/mvme88k/include/m88410.h
index a2354fa1068..d0b5d464823 100644
--- a/sys/arch/mvme88k/include/m88410.h
+++ b/sys/arch/mvme88k/include/m88410.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: m88410.h,v 1.11 2005/04/30 16:42:37 miod Exp $ */
+/* $OpenBSD: m88410.h,v 1.12 2005/12/12 20:36:32 miod Exp $ */
/*
* Copyright (c) 2001 Steve Murphree, Jr.
* All rights reserved.
@@ -36,132 +36,15 @@
#ifdef _KERNEL
/*
- * MC88410 External Cache Controller definitions
- * This is only available on MVME197DP/SP models.
+ * MC88410 External Cache Controller definitions.
+ * This is only available on MVME197 SP, DP and QP models.
*/
-#include <machine/asm_macro.h>
-#include <machine/psl.h>
#include <mvme88k/dev/busswreg.h>
-#define XCC_NOP "0x00"
-#define XCC_FLUSH_PAGE "0x01"
-#define XCC_FLUSH_ALL "0x02"
-#define XCC_INVAL_ALL "0x03"
-#define XCC_ADDR 0xff800000
-
-static __inline__ void
-mc88410_flush_page(paddr_t physaddr)
-{
- paddr_t xccaddr = XCC_ADDR | (physaddr >> PGSHIFT);
- u_int psr;
- u_int16_t bs_gcsr, bs_romcr;
-
- bs_gcsr = *(volatile u_int16_t *)(BS_BASE + BS_GCSR);
- bs_romcr = *(volatile u_int16_t *)(BS_BASE + BS_ROMCR);
- /* mask misaligned exceptions */
- set_psr((psr = get_psr()) | PSR_MXM);
- /* clear WEN0 and WEN1 in ROMCR (disables writes to FLASH) */
- *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) =
- bs_romcr & ~(BS_ROMCR_WEN0 | BS_ROMCR_WEN1);
- /* set XCC bit in GCSR (0xff8xxxxx now decodes to mc88410) */
- *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr | BS_GCSR_XCC;
-
- /* load the value of upper32 into r2 */
- __asm__ __volatile__("or r2,r0," XCC_FLUSH_PAGE);
- /* load the value of lower32 into r3 (always 0) */
- __asm__ __volatile__("or r3,r0,r0");
- /* load the value of xccaddr into r4 */
- __asm__ __volatile__("or.u r5,r0,hi16(%0)" : : "r" (xccaddr));
- __asm__ __volatile__("ld r4,r5,lo16(%0)" : : "r" (xccaddr));
- /* make the double write. bang! */
- __asm__ __volatile__("st.d r2,r4,0");
-
- /* spin until the operation starts */
- while ((*(volatile u_int32_t *)(BS_BASE + BS_XCCR) & BS_XCC_FBSY) == 0)
- ;
-
- /* restore PSR and friends */
- set_psr(psr);
- flush_pipeline();
- *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr;
- *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) = bs_romcr;
-}
-
-static __inline__ void
-mc88410_flush(void)
-{
- u_int psr;
- u_int16_t bs_gcsr, bs_romcr;
-
- bs_gcsr = *(volatile u_int16_t *)(BS_BASE + BS_GCSR);
- bs_romcr = *(volatile u_int16_t *)(BS_BASE + BS_ROMCR);
- /* mask misaligned exceptions */
- set_psr((psr = get_psr()) | PSR_MXM);
- /* clear WEN0 and WEN1 in ROMCR (disables writes to FLASH) */
- *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) =
- bs_romcr & ~(BS_ROMCR_WEN0 | BS_ROMCR_WEN1);
- /* set XCC bit in GCSR (0xFF8xxxxx now decodes to mc88410) */
- *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr | BS_GCSR_XCC;
-
- /* load the value of upper32 into r2 */
- __asm__ __volatile__("or r2,r0," XCC_FLUSH_ALL);
- /* load the value of lower32 into r3 (always 0) */
- __asm__ __volatile__("or r3,r0,r0");
- /* load the value of xccaddr into r4 */
- __asm__ __volatile__("or.u r5,r0,hi16(0xff800000)");
- __asm__ __volatile__("or r4,r5,r0");
- /* make the double write. bang! */
- __asm__ __volatile__("st.d r2,r4,0");
-
- /* spin until the operation starts */
- while ((*(volatile u_int32_t *)(BS_BASE + BS_XCCR) & BS_XCC_FBSY) == 0)
- ;
-
- /* restore PSR and friends */
- set_psr(psr);
- flush_pipeline();
- *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr;
- *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) = bs_romcr;
-}
-
-static __inline__ void
-mc88410_inval(void)
-{
- u_int psr;
- u_int16_t bs_gcsr, bs_romcr;
-
- bs_gcsr = *(volatile u_int16_t *)(BS_BASE + BS_GCSR);
- bs_romcr = *(volatile u_int16_t *)(BS_BASE + BS_ROMCR);
-
- /* mask misaligned exceptions */
- set_psr((psr = get_psr()) | PSR_MXM);
- /* clear WEN0 and WEN1 in ROMCR (disables writes to FLASH) */
- *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) =
- bs_romcr & ~(BS_ROMCR_WEN0 | BS_ROMCR_WEN1);
- /* set XCC bit in GCSR (0xFF8xxxxx now decodes to mc88410) */
- *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr | BS_GCSR_XCC;
-
- /* load the value of upper32 into r2 */
- __asm__ __volatile__("or r2,r0," XCC_INVAL_ALL);
- /* load the value of lower32 into r3 (always 0) */
- __asm__ __volatile__("or r3,r0,r0");
- /* load the value of xccaddr into r4 */
- __asm__ __volatile__("or.u r5,r0,hi16(0xff800000)");
- __asm__ __volatile__("or r4,r5,r0");
- /* make the double write. bang! */
- __asm__ __volatile__("st.d r2,r4,0");
-
- /* spin until the operation starts */
- while ((*(volatile u_int32_t *)(BS_BASE + BS_XCCR) & BS_XCC_FBSY) == 0)
- ;
-
- /* restore PSR and friends */
- set_psr(psr);
- flush_pipeline();
- *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr;
- *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) = bs_romcr;
-}
+void mc88410_flush_page(paddr_t);
+void mc88410_flush(void);
+void mc88410_inval(void);
static __inline__ void
mc88410_sync(void)
diff --git a/sys/arch/mvme88k/mvme88k/m88410.c b/sys/arch/mvme88k/mvme88k/m88410.c
new file mode 100644
index 00000000000..a7c767eda6c
--- /dev/null
+++ b/sys/arch/mvme88k/mvme88k/m88410.c
@@ -0,0 +1,154 @@
+/* $OpenBSD: m88410.c,v 1.1 2005/12/12 20:36:33 miod Exp $ */
+/*
+ * Copyright (c) 2001 Steve Murphree, Jr.
+ * 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.
+ * 3. All advertising materials mentioning features or use of this software
+ * must display the following acknowledgement:
+ * This product includes software developed by Steve Murphree.
+ * 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
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR 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/param.h>
+#include <sys/systm.h>
+
+#include <machine/asm_macro.h>
+#include <machine/m88410.h>
+
+#include <mvme88k/dev/busswreg.h>
+
+#define XCC_NOP "0x00"
+#define XCC_FLUSH_PAGE "0x01"
+#define XCC_FLUSH_ALL "0x02"
+#define XCC_INVAL_ALL "0x03"
+#define XCC_ADDR 0xff800000
+
+void
+mc88410_flush_page(paddr_t physaddr)
+{
+ paddr_t xccaddr = XCC_ADDR | (physaddr >> PGSHIFT);
+ u_int psr;
+ u_int16_t bs_gcsr, bs_romcr;
+
+ bs_gcsr = *(volatile u_int16_t *)(BS_BASE + BS_GCSR);
+ bs_romcr = *(volatile u_int16_t *)(BS_BASE + BS_ROMCR);
+
+ /* mask misaligned exceptions */
+ set_psr((psr = get_psr()) | PSR_MXM);
+
+ /* clear WEN0 and WEN1 in ROMCR (disables writes to FLASH) */
+ *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) =
+ bs_romcr & ~(BS_ROMCR_WEN0 | BS_ROMCR_WEN1);
+
+ /* set XCC bit in GCSR (0xff8xxxxx now decodes to mc88410) */
+ *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr | BS_GCSR_XCC;
+
+ /* send command */
+ __asm__ __volatile__ (
+ "or r2, r0, " XCC_FLUSH_PAGE ";"
+ "or r3, r0, r0;"
+ "st.d r2, %0, 0" : : "r" (xccaddr) : "r2", "r3");
+
+ /* spin until the operation starts */
+ while ((*(volatile u_int32_t *)(BS_BASE + BS_XCCR) & BS_XCC_FBSY) != 0)
+ ;
+
+ /* restore PSR and friends */
+ set_psr(psr);
+ flush_pipeline();
+ *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr;
+ *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) = bs_romcr;
+}
+
+void
+mc88410_flush(void)
+{
+ u_int psr;
+ u_int16_t bs_gcsr, bs_romcr;
+
+ bs_gcsr = *(volatile u_int16_t *)(BS_BASE + BS_GCSR);
+ bs_romcr = *(volatile u_int16_t *)(BS_BASE + BS_ROMCR);
+
+ /* mask misaligned exceptions */
+ set_psr((psr = get_psr()) | PSR_MXM);
+
+ /* clear WEN0 and WEN1 in ROMCR (disables writes to FLASH) */
+ *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) =
+ bs_romcr & ~(BS_ROMCR_WEN0 | BS_ROMCR_WEN1);
+
+ /* set XCC bit in GCSR (0xFF8xxxxx now decodes to mc88410) */
+ *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr | BS_GCSR_XCC;
+
+ /* send command */
+ __asm__ __volatile__ (
+ "or r2, r0, " XCC_FLUSH_ALL ";"
+ "or r3, r0, r0;"
+ "st.d r2, %0, 0" : : "r" (XCC_ADDR) : "r2", "r3");
+
+ /* spin until the operation starts */
+ while ((*(volatile u_int32_t *)(BS_BASE + BS_XCCR) & BS_XCC_FBSY) != 0)
+ ;
+
+ /* restore PSR and friends */
+ set_psr(psr);
+ flush_pipeline();
+ *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr;
+ *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) = bs_romcr;
+}
+
+void
+mc88410_inval(void)
+{
+ u_int psr;
+ u_int16_t bs_gcsr, bs_romcr;
+
+ bs_gcsr = *(volatile u_int16_t *)(BS_BASE + BS_GCSR);
+ bs_romcr = *(volatile u_int16_t *)(BS_BASE + BS_ROMCR);
+
+ /* mask misaligned exceptions */
+ set_psr((psr = get_psr()) | PSR_MXM);
+
+ /* clear WEN0 and WEN1 in ROMCR (disables writes to FLASH) */
+ *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) =
+ bs_romcr & ~(BS_ROMCR_WEN0 | BS_ROMCR_WEN1);
+
+ /* set XCC bit in GCSR (0xFF8xxxxx now decodes to mc88410) */
+ *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr | BS_GCSR_XCC;
+
+ /* send command */
+ __asm__ __volatile__ (
+ "or r2, r0, " XCC_INVAL_ALL ";"
+ "or r3, r0, r0;"
+ "st.d r2, %0, 0" : : "r" (XCC_ADDR) : "r2", "r3");
+
+ /* wait for the operation to be completed */
+ while (*(volatile u_int32_t *)(BS_BASE + BS_XCCR) != 0)
+ ;
+
+ /* restore PSR and friends */
+ set_psr(psr);
+ flush_pipeline();
+ *(volatile u_int16_t *)(BS_BASE + BS_GCSR) = bs_gcsr;
+ *(volatile u_int16_t *)(BS_BASE + BS_ROMCR) = bs_romcr;
+}