summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2005-09-25 20:04:04 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2005-09-25 20:04:04 +0000
commit0b4beffd4c26ac02605a816373239e2645d8e14d (patch)
tree690f4b29ab90aabf301d65fd2f098bc5b5d70e84 /sys/arch
parentf711e4a2fac8c28e3468ac7ceb99f416941a9ec5 (diff)
On Sun4m, be sure to steal the overlapping part of the iommu dvma space
and kernel_map from the latter. Otherwise, very bad things happen when kernel_map usage grows.
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sparc/sparc/machdep.c18
1 files changed, 17 insertions, 1 deletions
diff --git a/sys/arch/sparc/sparc/machdep.c b/sys/arch/sparc/sparc/machdep.c
index 7112f2b4c31..82a8bf285ed 100644
--- a/sys/arch/sparc/sparc/machdep.c
+++ b/sys/arch/sparc/sparc/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.106 2005/08/18 18:40:51 kettenis Exp $ */
+/* $OpenBSD: machdep.c,v 1.107 2005/09/25 20:04:03 miod Exp $ */
/* $NetBSD: machdep.c,v 1.85 1997/09/12 08:55:02 pk Exp $ */
/*
@@ -265,10 +265,26 @@ cpu_startup()
*/
dvma_base = CPU_ISSUN4M ? DVMA4M_BASE : DVMA_BASE;
dvma_end = CPU_ISSUN4M ? DVMA4M_END : DVMA_END;
+#if defined(SUN4M)
+ if (CPU_ISSUN4M) {
+ /*
+ * The DVMA space we want partially overrides kernel_map.
+ * Allocate it in kernel_map as well to prevent it from being
+ * used for other things.
+ */
+ if (uvm_map(kernel_map, &dvma_base,
+ vm_map_max(kernel_map) - dvma_base,
+ NULL, UVM_UNKNOWN_OFFSET, 0,
+ UVM_MAPFLAG(UVM_PROT_NONE, UVM_PROT_NONE, UVM_INH_NONE,
+ UVM_ADV_NORMAL, 0)))
+ panic("startup: can not steal dvma map");
+ }
+#endif
phys_map = uvm_map_create(pmap_kernel(), dvma_base, dvma_end,
VM_MAP_INTRSAFE);
if (phys_map == NULL)
panic("unable to create DVMA map");
+
/*
* Allocate DVMA space and dump into a privately managed
* resource map for double mappings which is usable from