Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libc/stdlib Stop calling reallocarr and just do the same...
details: https://anonhg.NetBSD.org/src/rev/d7820b40ae45
branches: trunk
changeset: 344584:d7820b40ae45
user: roy <roy%NetBSD.org@localhost>
date: Tue Apr 05 15:01:26 2016 +0000
description:
Stop calling reallocarr and just do the same bounds checking but without
messing around with copying pointers which was causing ssh to crash.
diffstat:
lib/libc/stdlib/reallocarray.c | 27 +++++++++++++++++----------
1 files changed, 17 insertions(+), 10 deletions(-)
diffs (48 lines):
diff -r f7b97a2cd2d7 -r d7820b40ae45 lib/libc/stdlib/reallocarray.c
--- a/lib/libc/stdlib/reallocarray.c Tue Apr 05 14:07:31 2016 +0000
+++ b/lib/libc/stdlib/reallocarray.c Tue Apr 05 15:01:26 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: reallocarray.c,v 1.5 2015/07/26 02:22:33 kamil Exp $ */
+/* $NetBSD: reallocarray.c,v 1.6 2016/04/05 15:01:26 roy Exp $ */
/* $OpenBSD: reallocarray.c,v 1.1 2014/05/08 21:43:49 deraadt Exp $ */
/*-
@@ -31,22 +31,29 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: reallocarray.c,v 1.5 2015/07/26 02:22:33 kamil Exp $");
+__RCSID("$NetBSD: reallocarray.c,v 1.6 2016/04/05 15:01:26 roy Exp $");
#define _OPENBSD_SOURCE
#include <errno.h>
+#include <limits.h>
#include <stdlib.h>
+#define SQRT_SIZE_MAX (((size_t)1) << (sizeof(size_t) * CHAR_BIT / 2))
void *
reallocarray(void *optr, size_t nmemb, size_t size)
{
- if (nmemb == 0 || size == 0)
- return realloc(optr, 0);
- int e = reallocarr(&optr, nmemb, size);
-
- if (e == 0)
- return optr;
- errno = e;
- return NULL;
+ /*
+ * Try to avoid division here.
+ *
+ * It isn't possible to overflow during multiplication if neither
+ * operand uses any of the most significant half of the bits.
+ */
+ if (__predict_false((nmemb | size) >= SQRT_SIZE_MAX &&
+ nmemb > SIZE_MAX / size))
+ {
+ errno = EOVERFLOW;
+ return NULL;
+ }
+ return realloc(optr, nmemb * size);
}
Home |
Main Index |
Thread Index |
Old Index