summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2007-12-26 22:22:46 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2007-12-26 22:22:46 +0000
commitab9fcfa5fff17ceff5f0a5eb863625150f59639c (patch)
tree6cb3340a7fbcd2e57e9f72a2953efabf55ba32c5
parent9f210b547660c3b686e67c84b085a88b72c427a1 (diff)
Since no cache flush/inval operation will occur before we enable D$, and
we never disable it, it is not necessary to check for D$ to be enabled before acting. That's a few more cycles spared.
-rw-r--r--sys/arch/mvme88k/mvme88k/m88110.c26
1 files changed, 6 insertions, 20 deletions
diff --git a/sys/arch/mvme88k/mvme88k/m88110.c b/sys/arch/mvme88k/mvme88k/m88110.c
index 019d2f3d2b2..9e74303965b 100644
--- a/sys/arch/mvme88k/mvme88k/m88110.c
+++ b/sys/arch/mvme88k/mvme88k/m88110.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: m88110.c,v 1.56 2007/12/26 22:21:41 miod Exp $ */
+/* $OpenBSD: m88110.c,v 1.57 2007/12/26 22:22:45 miod Exp $ */
/*
* Copyright (c) 1998 Steve Murphree, Jr.
* All rights reserved.
@@ -460,6 +460,9 @@ m88110_flush_tlb(cpuid_t cpu, u_int kernel, vaddr_t vaddr, u_int count)
* incoherent with the proper state of memory. Before 5.0 the flush
* command was treated like a nop when the cache was disabled. This
* is no longer the case.''
+ *
+ * Since we always enable the data cache, and no cmmu cache operation
+ * will occur before we do, it is not necessary to pay attention to this.
*/
#define trunc_cache_line(a) ((a) & ~(MC88110_CACHE_LINE - 1))
@@ -478,8 +481,7 @@ m88110_flush_cache(cpuid_t cpu, paddr_t pa, psize_t size)
set_psr(psr | PSR_IND);
mc88110_inval_inst();
- if (get_dctl() & CMMU_DCTL_CEN)
- mc88110_flush_data();
+ mc88110_flush_data();
set_psr(psr);
}
@@ -502,9 +504,7 @@ m88410_flush_cache(cpuid_t cpu, paddr_t pa, psize_t size)
mc88110_inval_inst();
/* flush all data to avoid errata invalidate */
- if (get_dctl() & CMMU_DCTL_CEN) {
- mc88110_flush_data();
- }
+ mc88110_flush_data();
CMMU_LOCK;
mc88410_flush();
CMMU_UNLOCK;
@@ -621,9 +621,6 @@ m88110_dma_cachectl(pmap_t pmap, vaddr_t _va, vsize_t _size, int op)
psr = get_psr();
set_psr(psr | PSR_IND);
- if (!ISSET(get_dctl(), CMMU_DCTL_CEN))
- size = 0;
-
if (op != DMA_CACHE_SYNC)
mc88110_inval_inst();
while (size != 0) {
@@ -682,8 +679,6 @@ m88410_dma_cachectl(pmap_t pmap, vaddr_t _va, vsize_t _size, int op)
if (op == DMA_CACHE_SYNC) {
va = trunc_page(_va);
size = round_page(_va + _size) - va;
- if (!ISSET(get_dctl(), CMMU_DCTL_CEN))
- size = 0;
CMMU_LOCK;
while (size != 0) {
if (pmap_extract(pmap, va, &pa) != FALSE) {
@@ -695,8 +690,6 @@ m88410_dma_cachectl(pmap_t pmap, vaddr_t _va, vsize_t _size, int op)
}
CMMU_UNLOCK;
} else {
- if (!ISSET(get_dctl(), CMMU_DCTL_CEN))
- size = 0;
mc88110_inval_inst();
while (size != 0) {
count = (va & PAGE_MASK) == 0 && size >= PAGE_SIZE ?
@@ -746,9 +739,6 @@ m88110_dma_cachectl_pa(paddr_t _pa, psize_t _size, int op)
psr = get_psr();
set_psr(psr | PSR_IND);
- if (!ISSET(get_dctl(), CMMU_DCTL_CEN))
- size = 0;
-
if (op != DMA_CACHE_SYNC)
mc88110_inval_inst();
while (size != 0) {
@@ -804,8 +794,6 @@ m88410_dma_cachectl_pa(paddr_t _pa, psize_t _size, int op)
if (op == DMA_CACHE_SYNC) {
pa = trunc_page(_pa);
size = round_page(_pa + _size) - pa;
- if (!ISSET(get_dctl(), CMMU_DCTL_CEN))
- size = 0;
CMMU_LOCK;
while (size != 0) {
m88110_cmmu_sync_cache(pa, PAGE_SIZE);
@@ -815,8 +803,6 @@ m88410_dma_cachectl_pa(paddr_t _pa, psize_t _size, int op)
}
CMMU_UNLOCK;
} else {
- if (!ISSET(get_dctl(), CMMU_DCTL_CEN))
- size = 0;
mc88110_inval_inst();
while (size != 0) {
count = (pa & PAGE_MASK) == 0 && size >= PAGE_SIZE ?