summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorArtur Grabowski <art@cvs.openbsd.org>1999-12-09 16:19:51 +0000
committerArtur Grabowski <art@cvs.openbsd.org>1999-12-09 16:19:51 +0000
commit1d609cf57cdab7a58a6bb93c8cbb2ae64bef81a7 (patch)
tree4a097dc68d1da4aa5e68d12362e6019ed22072e2 /sys/arch
parent816f2526fc8aa16fb14c8bea006807bbaf90656d (diff)
Since we uncache the memory in dvma_malloc, it is a good idea to recacheit in
dvma_free.
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sparc/sparc/vm_machdep.c24
1 files changed, 18 insertions, 6 deletions
diff --git a/sys/arch/sparc/sparc/vm_machdep.c b/sys/arch/sparc/sparc/vm_machdep.c
index 2830cfa2045..f652a915546 100644
--- a/sys/arch/sparc/sparc/vm_machdep.c
+++ b/sys/arch/sparc/sparc/vm_machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vm_machdep.c,v 1.11 1999/09/03 18:02:00 art Exp $ */
+/* $OpenBSD: vm_machdep.c,v 1.12 1999/12/09 16:19:50 art Exp $ */
/* $NetBSD: vm_machdep.c,v 1.30 1997/03/10 23:55:40 pk Exp $ */
/*
@@ -108,6 +108,10 @@ kdvma_mapin(va, len, canwait)
return ((caddr_t)dvma_mapin(kernel_map, (vaddr_t)va, len, canwait));
}
+#if defined(SUN4M)
+extern int has_iocache;
+#endif
+
caddr_t
dvma_malloc(len, kaddr, flags)
size_t len;
@@ -116,9 +120,6 @@ dvma_malloc(len, kaddr, flags)
{
vaddr_t kva;
vaddr_t dva;
-#if defined(SUN4M)
- extern int has_iocache;
-#endif
len = round_page(len);
kva = (vaddr_t)malloc(len, M_DEVBUF, flags);
@@ -128,7 +129,7 @@ dvma_malloc(len, kaddr, flags)
#if defined(SUN4M)
if (!has_iocache)
#endif
- kvm_uncache((caddr_t)kva, len >> PGSHIFT);
+ kvm_uncache((caddr_t)kva, atop(len));
*(vaddr_t *)kaddr = kva;
dva = dvma_mapin(kernel_map, kva, len, (flags & M_NOWAIT) ? 0 : 1);
@@ -147,7 +148,18 @@ dvma_free(dva, len, kaddr)
{
vaddr_t kva = *(vaddr_t *)kaddr;
- dvma_mapout((vaddr_t)dva, kva, round_page(len));
+ len = round_page(len);
+
+ dvma_mapout((vaddr_t)dva, kva, len);
+ /*
+ * Even if we're freeing memory here, we can't be sure that it will
+ * be unmapped, so we must recache the memory range to avoid impact
+ * on other kernel subsystems.
+ */
+#if defined(SUN4M)
+ if (!has_iocache)
+#endif
+ kvm_recache(kaddr, atop(len));
free((void *)kva, M_DEVBUF);
}