Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/kern Add sanity check: make sure we retrieve a valid ite...



details:   https://anonhg.NetBSD.org/src/rev/b76d0d0f09a4
branches:  trunk
changeset: 449584:b76d0d0f09a4
user:      maxv <maxv%NetBSD.org@localhost>
date:      Mon Mar 11 20:38:27 2019 +0000

description:
Add sanity check: make sure we retrieve a valid item header, by checking
its page address against the one we computed. If there's a mismatch it
means the buffer does not belong to the pool, and we panic.

diffstat:

 sys/kern/subr_pool.c |  11 ++++++++---
 1 files changed, 8 insertions(+), 3 deletions(-)

diffs (32 lines):

diff -r 3023e1922325 -r b76d0d0f09a4 sys/kern/subr_pool.c
--- a/sys/kern/subr_pool.c      Mon Mar 11 20:21:32 2019 +0000
+++ b/sys/kern/subr_pool.c      Mon Mar 11 20:38:27 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: subr_pool.c,v 1.234 2019/03/11 20:21:32 maxv Exp $     */
+/*     $NetBSD: subr_pool.c,v 1.235 2019/03/11 20:38:27 maxv Exp $     */
 
 /*
  * Copyright (c) 1997, 1999, 2000, 2002, 2007, 2008, 2010, 2014, 2015, 2018
@@ -33,7 +33,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: subr_pool.c,v 1.234 2019/03/11 20:21:32 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: subr_pool.c,v 1.235 2019/03/11 20:38:27 maxv Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_ddb.h"
@@ -431,7 +431,12 @@
                    (void *)((uintptr_t)v & pp->pr_alloc->pa_pagemask);
 
                if ((pp->pr_roflags & PR_PHINPAGE) != 0) {
-                       ph = (struct pool_item_header *)((char *)page + pp->pr_phoffset);
+                       ph = (struct pool_item_header *)
+                           ((char *)page + pp->pr_phoffset);
+                       if (__predict_false((void *)ph->ph_page != page)) {
+                               panic("%s: [%s] item not part of pool",
+                                   __func__, pp->pr_wchan);
+                       }
                } else {
                        tmp.ph_page = page;
                        ph = SPLAY_FIND(phtree, &pp->pr_phtree, &tmp);



Home | Main Index | Thread Index | Old Index