summaryrefslogtreecommitdiff
path: root/sys/arch/mvme88k
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/mvme88k')
-rw-r--r--sys/arch/mvme88k/mvme88k/m88410.c35
1 files changed, 14 insertions, 21 deletions
diff --git a/sys/arch/mvme88k/mvme88k/m88410.c b/sys/arch/mvme88k/mvme88k/m88410.c
index a7c767eda6c..7537f81399a 100644
--- a/sys/arch/mvme88k/mvme88k/m88410.c
+++ b/sys/arch/mvme88k/mvme88k/m88410.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: m88410.c,v 1.1 2005/12/12 20:36:33 miod Exp $ */
+/* $OpenBSD: m88410.c,v 1.2 2006/05/07 17:44:28 miod Exp $ */
/*
* Copyright (c) 2001 Steve Murphree, Jr.
* All rights reserved.
@@ -54,7 +54,10 @@ mc88410_flush_page(paddr_t physaddr)
bs_gcsr = *(volatile u_int16_t *)(BS_BASE + BS_GCSR);
bs_romcr = *(volatile u_int16_t *)(BS_BASE + BS_ROMCR);
- /* mask misaligned exceptions */
+ /*
+ * Since the page number is unlikely to be a multiple of 4, we need
+ * to mask misaligned exceptions.
+ */
set_psr((psr = get_psr()) | PSR_MXM);
/* clear WEN0 and WEN1 in ROMCR (disables writes to FLASH) */
@@ -70,7 +73,7 @@ mc88410_flush_page(paddr_t physaddr)
"or r3, r0, r0;"
"st.d r2, %0, 0" : : "r" (xccaddr) : "r2", "r3");
- /* spin until the operation starts */
+ /* spin until the operation is complete */
while ((*(volatile u_int32_t *)(BS_BASE + BS_XCCR) & BS_XCC_FBSY) != 0)
;
@@ -84,15 +87,11 @@ mc88410_flush_page(paddr_t physaddr)
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);
@@ -106,13 +105,10 @@ mc88410_flush(void)
"or r3, r0, r0;"
"st.d r2, %0, 0" : : "r" (XCC_ADDR) : "r2", "r3");
- /* spin until the operation starts */
+ /* spin until the operation is complete */
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;
}
@@ -120,15 +116,12 @@ mc88410_flush(void)
void
mc88410_inval(void)
{
- u_int psr;
u_int16_t bs_gcsr, bs_romcr;
+ u_int32_t dummy;
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);
@@ -142,13 +135,13 @@ mc88410_inval(void)
"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)
- ;
+ /*
+ * The 88410 will not let the 88110 access it until the
+ * invalidate all operation is complete. Simply force a read
+ * access which will spin as long as necessary.
+ */
+ dummy = *(volatile u_int32_t *)(BS_BASE + BS_XCCR);
- /* 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;
}