summaryrefslogtreecommitdiffstats
path: root/crypto
diff options
context:
space:
mode:
authornectar <nectar@FreeBSD.org>2003-09-16 06:11:58 +0000
committernectar <nectar@FreeBSD.org>2003-09-16 06:11:58 +0000
commit8cd211c5614d04163ef750283efd53dd2f129e68 (patch)
treec58c3115c56af308f662f9bddeeed7eb37cc33c8 /crypto
parent7fc179286a2a92255f1c64ea774523517a4088d8 (diff)
downloadFreeBSD-src-8cd211c5614d04163ef750283efd53dd2f129e68.zip
FreeBSD-src-8cd211c5614d04163ef750283efd53dd2f129e68.tar.gz
Do not record expanded size before attempting to reallocate associated
memory. Obtained from: OpenBSD
Diffstat (limited to 'crypto')
-rw-r--r--crypto/openssh/buffer.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/crypto/openssh/buffer.c b/crypto/openssh/buffer.c
index ad04b26..8ff8c2f 100644
--- a/crypto/openssh/buffer.c
+++ b/crypto/openssh/buffer.c
@@ -12,7 +12,7 @@
*/
#include "includes.h"
-RCSID("$OpenBSD: buffer.c,v 1.16 2002/06/26 08:54:18 markus Exp $");
+RCSID("$OpenBSD: buffer.c,v 1.17 2003/09/16 03:03:47 deraadt Exp $");
#include "xmalloc.h"
#include "buffer.h"
@@ -69,6 +69,7 @@ buffer_append(Buffer *buffer, const void *data, u_int len)
void *
buffer_append_space(Buffer *buffer, u_int len)
{
+ u_int newlen;
void *p;
if (len > 0x100000)
@@ -98,11 +99,13 @@ restart:
goto restart;
}
/* Increase the size of the buffer and retry. */
- buffer->alloc += len + 32768;
- if (buffer->alloc > 0xa00000)
+
+ newlen = buffer->alloc + len + 32768;
+ if (newlen > 0xa00000)
fatal("buffer_append_space: alloc %u not supported",
- buffer->alloc);
- buffer->buf = xrealloc(buffer->buf, buffer->alloc);
+ newlen);
+ buffer->buf = xrealloc(buffer->buf, newlen);
+ buffer->alloc = newlen;
goto restart;
/* NOTREACHED */
}
OpenPOWER on IntegriCloud