Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/kern Unlink KMEM_GUARD leftovers.
details: https://anonhg.NetBSD.org/src/rev/19a882702b28
branches: trunk
changeset: 1002797:19a882702b28
user: maxv <maxv%NetBSD.org@localhost>
date: Thu Aug 15 12:24:08 2019 +0000
description:
Unlink KMEM_GUARD leftovers.
diffstat:
share/man/man9/kmem.9 | 88 +--------------------------------------
sys/arch/mips/mips/pmap_machdep.c | 10 +---
sys/kern/files.kern | 6 +-
3 files changed, 6 insertions(+), 98 deletions(-)
diffs (168 lines):
diff -r 55025732aca7 -r 19a882702b28 share/man/man9/kmem.9
--- a/share/man/man9/kmem.9 Thu Aug 15 12:06:42 2019 +0000
+++ b/share/man/man9/kmem.9 Thu Aug 15 12:24:08 2019 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: kmem.9,v 1.23 2017/11/07 18:36:27 christos Exp $
+.\" $NetBSD: kmem.9,v 1.24 2019/08/15 12:24:08 maxv Exp $
.\"
.\" Copyright (c)2006 YAMAMOTO Takashi,
.\" All rights reserved.
@@ -25,7 +25,7 @@
.\" SUCH DAMAGE.
.\"
.\" ------------------------------------------------------------
-.Dd November 7, 2017
+.Dd August 15, 2019
.Dt KMEM 9
.Os
.\" ------------------------------------------------------------
@@ -69,8 +69,6 @@
.\" ------------------------------------------------------------
.Pp
.Cd "options KMEM_SIZE"
-.Cd "options KMEM_REDZONE"
-.Cd "options KMEM_GUARD"
.Sh DESCRIPTION
.Fn kmem_alloc
allocates kernel wired memory.
@@ -260,89 +258,7 @@
.Pp
.Dv KMEM_SIZE
is enabled by default on
-.Dv DIAGNOSTIC
-and
-.Dv DEBUG .
-.Ss KMEM_REDZONE
-Kernels compiled with the
-.Dv KMEM_REDZONE
-option add a dynamic pattern of two bytes at the end of each allocated
-buffer, and check this pattern when freeing to ensure the caller hasn't
-written outside the requested area.
-This option does not introduce a significant performance impact,
-but has two drawbacks: it only catches write overflows, and catches
-them only on
-.Fn kmem_free .
-.Pp
-.Dv KMEM_REDZONE
-is enabled by default on
.Dv DIAGNOSTIC .
-.Ss KMEM_GUARD
-Kernels compiled with the
-.Dv KMEM_GUARD
-option perform CPU intensive sanity checks on kmem operations.
-It adds additional, very high overhead runtime verification to kmem
-operations.
-It must be enabled with
-.Dv KMEM_SIZE .
-.Pp
-.Dv KMEM_GUARD
-tries to catch the following types of bugs:
-.Bl -bullet
-.It
-Overflow at time of occurrence, by means of a guard page.
-An unmapped guard page sits immediately after the requested area;
-a read/write overflow therefore triggers a page fault.
-.It
-Underflow at
-.Fn kmem_free ,
-by using
-.Dv KMEM_SIZE Ap s
-registered size.
-If an underflow occurs, the size stored by
-.Dv KMEM_SIZE
-will be overwritten, which means that when freeing, the kernel will
-spot the mismatch.
-.It
-Use-after-free at time of occurrence.
-When freeing, the memory is unmapped, and depending on the value
-of kmem_guard_depth, the kernel will more or less delay the recycling
-of that memory.
-Which means that any ulterior read/write access to the memory will
-trigger a page fault, given it hasn't been recycled yet.
-.El
-.Pp
-To enable it, boot the system with the
-.Fl d
-option, which causes the debugger to be entered early during the kernel
-boot process.
-Issue commands such as the following:
-.Bd -literal
-db> w kmem_guard_depth 0t30000
-db> c
-.Ed
-.Pp
-This instructs
-.Dv kmem_guard
-to queue up to 60000 (30000*2) pages of unmapped KVA to catch
-use-after-free type errors.
-When
-.Fn kmem_free
-is called, memory backing a freed item is unmapped and the kernel VA
-space pushed onto a FIFO.
-The VA space will not be reused until another 30k items have been freed.
-Until reused the kernel will catch invalid accesses and panic with a page fault.
-Limitations:
-.Bl -bullet
-.It
-It has a severe impact on performance.
-.It
-It is best used on a 64-bit machine with lots of RAM.
-.El
-.Pp
-.Dv KMEM_GUARD
-is enabled by default on
-.Dv DEBUG .
.Sh RETURN VALUES
On success,
.Fn kmem_alloc ,
diff -r 55025732aca7 -r 19a882702b28 sys/arch/mips/mips/pmap_machdep.c
--- a/sys/arch/mips/mips/pmap_machdep.c Thu Aug 15 12:06:42 2019 +0000
+++ b/sys/arch/mips/mips/pmap_machdep.c Thu Aug 15 12:24:08 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pmap_machdep.c,v 1.24 2019/07/14 09:31:33 skrll Exp $ */
+/* $NetBSD: pmap_machdep.c,v 1.25 2019/08/15 12:24:08 maxv Exp $ */
/*-
* Copyright (c) 1998, 2001 The NetBSD Foundation, Inc.
@@ -67,7 +67,7 @@
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap_machdep.c,v 1.24 2019/07/14 09:31:33 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmap_machdep.c,v 1.25 2019/08/15 12:24:08 maxv Exp $");
/*
* Manages physical address maps.
@@ -378,12 +378,6 @@
sysmap_size = (VM_PHYS_SIZE + (ubc_nwins << ubc_winshift) +
bufsz + 16 * NCARGS + pager_map_size) / NBPG +
(maxproc * UPAGES) + nkmempages;
-#ifdef DEBUG
- {
- extern int kmem_guard_depth;
- sysmap_size += kmem_guard_depth;
- }
-#endif
#ifdef SYSVSHM
sysmap_size += shminfo.shmall;
diff -r 55025732aca7 -r 19a882702b28 sys/kern/files.kern
--- a/sys/kern/files.kern Thu Aug 15 12:06:42 2019 +0000
+++ b/sys/kern/files.kern Thu Aug 15 12:24:08 2019 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.kern,v 1.34 2019/04/04 20:19:07 christos Exp $
+# $NetBSD: files.kern,v 1.35 2019/08/15 12:24:08 maxv Exp $
#
# kernel sources
@@ -123,9 +123,7 @@
file kern/subr_kcpuset.c kern
file kern/subr_kleak.c kleak
file kern/subr_kcov.c kcov
-defflag opt_kmem.h KMEM_GUARD
- KMEM_SIZE
-defparam opt_kmem.h KMEM_GUARD_DEPTH
+defflag opt_kmem.h KMEM_SIZE
file kern/subr_kmem.c kern
file kern/subr_kobj.c kern
file kern/subr_kobj_vfs.c kern
Home |
Main Index |
Thread Index |
Old Index