summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorArtur Grabowski <art@cvs.openbsd.org>1999-02-26 04:32:37 +0000
committerArtur Grabowski <art@cvs.openbsd.org>1999-02-26 04:32:37 +0000
commit560c28f74fe95716342778a00ac6488512574387 (patch)
treeafd7cddc7ba402aacf3030760cd97f5d361a8327 /sys/arch
parent95d534e12cf193761abf980106eafeca9529ca62 (diff)
kmem allocation changes for uvm
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/i386/i386/gdt.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/sys/arch/i386/i386/gdt.c b/sys/arch/i386/i386/gdt.c
index 1f6be4d6c1c..0ff2b7c30a1 100644
--- a/sys/arch/i386/i386/gdt.c
+++ b/sys/arch/i386/i386/gdt.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: gdt.c,v 1.10 1996/05/30 09:30:06 deraadt Exp $ */
+/* $OpenBSD: gdt.c,v 1.11 1999/02/26 04:32:36 art Exp $ */
/* $NetBSD: gdt.c,v 1.8 1996/05/03 19:42:06 christos Exp $ */
/*-
@@ -45,6 +45,10 @@
#include <vm/vm.h>
#include <vm/vm_kern.h>
+#if defined(UVM)
+#include <uvm/uvm_extern.h>
+#endif
+
#include <machine/gdt.h>
#define MINGDTSIZ 512
@@ -165,10 +169,16 @@ gdt_init()
min_len = MINGDTSIZ * sizeof(union descriptor);
gdt_size = MINGDTSIZ;
+#if defined(UVM)
+ dynamic_gdt = (union descriptor *)uvm_km_valloc(kernel_map, max_len);
+ uvm_map_pageable(kernel_map, (vaddr_t)dynamic_gdt,
+ (vaddr_t)dynamic_gdt + min_len, FALSE);
+#else
dynamic_gdt = (union descriptor *)kmem_alloc_pageable(kernel_map,
max_len);
vm_map_pageable(kernel_map, (vm_offset_t)dynamic_gdt,
(vm_offset_t)dynamic_gdt + min_len, FALSE);
+#endif
bcopy(gdt, dynamic_gdt, NGDT * sizeof(union descriptor));
setregion(&region, dynamic_gdt, max_len - 1);
@@ -184,8 +194,13 @@ gdt_grow()
gdt_size <<= 1;
new_len = old_len << 1;
+#if defined(UVM)
+ uvm_map_pageable(kernel_map, (vaddr_t)dynamic_gdt + old_len,
+ (vaddr_t)dynamic_gdt + new_len, FALSE);
+#else
vm_map_pageable(kernel_map, (vm_offset_t)dynamic_gdt + old_len,
(vm_offset_t)dynamic_gdt + new_len, FALSE);
+#endif
}
void
@@ -196,9 +211,13 @@ gdt_shrink()
old_len = gdt_size * sizeof(union descriptor);
gdt_size >>= 1;
new_len = old_len >> 1;
-
+#if defined(UVM)
+ uvm_map_pageable(kernel_map, (vaddr_t)dynamic_gdt + new_len,
+ (vaddr_t)dynamic_gdt + old_len, TRUE);
+#else
vm_map_pageable(kernel_map, (vm_offset_t)dynamic_gdt + new_len,
(vm_offset_t)dynamic_gdt + old_len, TRUE);
+#endif
}
/*