Module Name:    src
Committed By:   snj
Date:           Thu Apr 23 02:33:18 UTC 2009

Modified Files:
        src/lib/libc/db/btree [netbsd-5]: bt_split.c
        src/lib/libc/db/hash [netbsd-5]: hash_buf.c
        src/lib/libc/db/mpool [netbsd-5]: mpool.c

Log Message:
Pull up following revision(s) (requested by christos in ticket #719):
        lib/libc/db/btree/bt_split.c: revision 1.19
        lib/libc/db/hash/hash_buf.c: revision 1.15
        lib/libc/db/mpool/mpool.c: revision 1.19
Avoid information leaks by zeroing memory, from FreeBSD (we had done some
already)


To generate a diff of this commit:
cvs rdiff -u -r1.17 -r1.17.4.1 src/lib/libc/db/btree/bt_split.c
cvs rdiff -u -r1.14 -r1.14.4.1 src/lib/libc/db/hash/hash_buf.c
cvs rdiff -u -r1.18 -r1.18.4.1 src/lib/libc/db/mpool/mpool.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/lib/libc/db/btree/bt_split.c
diff -u src/lib/libc/db/btree/bt_split.c:1.17 src/lib/libc/db/btree/bt_split.c:1.17.4.1
--- src/lib/libc/db/btree/bt_split.c:1.17	Thu Sep 11 12:58:00 2008
+++ src/lib/libc/db/btree/bt_split.c	Thu Apr 23 02:33:17 2009
@@ -1,4 +1,4 @@
-/*	$NetBSD: bt_split.c,v 1.17 2008/09/11 12:58:00 joerg Exp $	*/
+/*	$NetBSD: bt_split.c,v 1.17.4.1 2009/04/23 02:33:17 snj Exp $	*/
 
 /*-
  * Copyright (c) 1990, 1993, 1994
@@ -37,7 +37,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: bt_split.c,v 1.17 2008/09/11 12:58:00 joerg Exp $");
+__RCSID("$NetBSD: bt_split.c,v 1.17.4.1 2009/04/23 02:33:17 snj Exp $");
 
 #include "namespace.h"
 #include <sys/types.h>
@@ -383,7 +383,7 @@
 	}
 
 	/* Put the new left page for the split into place. */
-	if ((l = (PAGE *)malloc(t->bt_psize)) == NULL) {
+	if ((l = calloc(1, t->bt_psize)) == NULL) {
 		mpool_put(t->bt_mp, r, 0);
 		return (NULL);
 	}

Index: src/lib/libc/db/hash/hash_buf.c
diff -u src/lib/libc/db/hash/hash_buf.c:1.14 src/lib/libc/db/hash/hash_buf.c:1.14.4.1
--- src/lib/libc/db/hash/hash_buf.c:1.14	Wed Sep 10 17:52:35 2008
+++ src/lib/libc/db/hash/hash_buf.c	Thu Apr 23 02:33:18 2009
@@ -1,4 +1,4 @@
-/*	$NetBSD: hash_buf.c,v 1.14 2008/09/10 17:52:35 joerg Exp $	*/
+/*	$NetBSD: hash_buf.c,v 1.14.4.1 2009/04/23 02:33:18 snj Exp $	*/
 
 /*-
  * Copyright (c) 1990, 1993, 1994
@@ -37,7 +37,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: hash_buf.c,v 1.14 2008/09/10 17:52:35 joerg Exp $");
+__RCSID("$NetBSD: hash_buf.c,v 1.14.4.1 2009/04/23 02:33:18 snj Exp $");
 
 /*
  * PACKAGE: hash
@@ -313,8 +313,10 @@
 		}
 		/* Check if we are freeing stuff */
 		if (do_free) {
-			if (bp->page)
+			if (bp->page) {
+				(void)memset(bp->page, 0, hashp->BSIZE);
 				free(bp->page);
+			}
 			BUF_REMOVE(bp);
 			free(bp);
 			bp = LRU;

Index: src/lib/libc/db/mpool/mpool.c
diff -u src/lib/libc/db/mpool/mpool.c:1.18 src/lib/libc/db/mpool/mpool.c:1.18.4.1
--- src/lib/libc/db/mpool/mpool.c:1.18	Thu Sep 11 12:58:00 2008
+++ src/lib/libc/db/mpool/mpool.c	Thu Apr 23 02:33:18 2009
@@ -1,4 +1,4 @@
-/*	$NetBSD: mpool.c,v 1.18 2008/09/11 12:58:00 joerg Exp $	*/
+/*	$NetBSD: mpool.c,v 1.18.4.1 2009/04/23 02:33:18 snj Exp $	*/
 
 /*-
  * Copyright (c) 1990, 1993, 1994
@@ -34,7 +34,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: mpool.c,v 1.18 2008/09/11 12:58:00 joerg Exp $");
+__RCSID("$NetBSD: mpool.c,v 1.18.4.1 2009/04/23 02:33:18 snj Exp $");
 
 #include "namespace.h"
 #include <sys/queue.h>
@@ -341,7 +341,7 @@
 			return (bp);
 		}
 
-new:	if ((bp = (BKT *)malloc((size_t)(sizeof(BKT) + mp->pagesize))) == NULL)
+new:	if ((bp = calloc(1, (size_t)(sizeof(BKT) + mp->pagesize))) == NULL)
 		return (NULL);
 #ifdef STATISTICS
 	++mp->pagealloc;

Reply via email to