diff options
author | Damien Miller <djm@mindrot.org> | 2010-02-11 21:35:08 +0100 |
---|---|---|
committer | Damien Miller <djm@mindrot.org> | 2010-02-11 21:35:08 +0100 |
commit | 17751bcab25681d341442fdc2386a30a6bea345e (patch) | |
tree | 95324d17124e072d255424307687168cb45d3d55 | |
parent | - (djm) add -lselinux to LIBS before calling AC_CHECK_FUNCS for (diff) | |
download | openssh-17751bcab25681d341442fdc2386a30a6bea345e.tar.xz openssh-17751bcab25681d341442fdc2386a30a6bea345e.zip |
- djm@cvs.openbsd.org 2010/02/02 22:49:34
[bufaux.c]
make buffer_get_string_ret() really non-fatal in all cases (it was
using buffer_get_int(), which could fatal() on buffer empty);
ok markus dtucker
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | bufaux.c | 7 |
2 files changed, 13 insertions, 2 deletions
@@ -1,3 +1,11 @@ +20100212 + - (djm) OpenBSD CVS Sync + - djm@cvs.openbsd.org 2010/02/02 22:49:34 + [bufaux.c] + make buffer_get_string_ret() really non-fatal in all cases (it was + using buffer_get_int(), which could fatal() on buffer empty); + ok markus dtucker + 20100210 - (djm) add -lselinux to LIBS before calling AC_CHECK_FUNCS for getseuserbyname; patch from calebcase AT gmail.com via @@ -1,4 +1,4 @@ -/* $OpenBSD: bufaux.c,v 1.47 2010/01/12 01:36:08 djm Exp $ */ +/* $OpenBSD: bufaux.c,v 1.48 2010/02/02 22:49:34 djm Exp $ */ /* * Author: Tatu Ylonen <ylo@cs.hut.fi> * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland @@ -166,7 +166,10 @@ buffer_get_string_ret(Buffer *buffer, u_int *length_ptr) u_int len; /* Get the length. */ - len = buffer_get_int(buffer); + if (buffer_get_int_ret(&len, buffer) != 0) { + error("buffer_get_string_ret: cannot extract length"); + return (NULL); + } if (len > 256 * 1024) { error("buffer_get_string_ret: bad string length %u", len); return (NULL); |