- djm@cvs.openbsd.org 2010/01/12 01:36:08

[buffer.h bufaux.c]
     add a buffer_get_string_ptr_ret() that does the same as
     buffer_get_string_ptr() but does not fatal() on error; ok dtucker@
This commit is contained in:
Darren Tucker 2010-01-12 19:45:59 +11:00
parent 1b0c2455da
commit ebc71d908c
3 changed files with 24 additions and 6 deletions

View File

@ -31,6 +31,10 @@
[session.c] [session.c]
Do not allow logins if /etc/nologin exists but is not readable by the user Do not allow logins if /etc/nologin exists but is not readable by the user
logging in. Noted by Jan.Pechanec at Sun, ok djm@ deraadt@ logging in. Noted by Jan.Pechanec at Sun, ok djm@ deraadt@
- djm@cvs.openbsd.org 2010/01/12 01:36:08
[buffer.h bufaux.c]
add a buffer_get_string_ptr_ret() that does the same as
buffer_get_string_ptr() but does not fatal() on error; ok dtucker@
20100110 20100110
- (dtucker) [configure.ac misc.c readconf.c servconf.c ssh-keyscan.c] - (dtucker) [configure.ac misc.c readconf.c servconf.c ssh-keyscan.c]

View File

@ -1,4 +1,4 @@
/* $OpenBSD: bufaux.c,v 1.46 2008/06/10 23:21:34 dtucker Exp $ */ /* $OpenBSD: bufaux.c,v 1.47 2010/01/12 01:36:08 djm Exp $ */
/* /*
* Author: Tatu Ylonen <ylo@cs.hut.fi> * Author: Tatu Ylonen <ylo@cs.hut.fi>
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
@ -198,14 +198,17 @@ buffer_get_string(Buffer *buffer, u_int *length_ptr)
} }
void * void *
buffer_get_string_ptr(Buffer *buffer, u_int *length_ptr) buffer_get_string_ptr_ret(Buffer *buffer, u_int *length_ptr)
{ {
void *ptr; void *ptr;
u_int len; u_int len;
len = buffer_get_int(buffer); if (buffer_get_int_ret(&len, buffer) != 0)
if (len > 256 * 1024) return NULL;
fatal("buffer_get_string_ptr: bad string length %u", len); if (len > 256 * 1024) {
error("buffer_get_string_ptr: bad string length %u", len);
return NULL;
}
ptr = buffer_ptr(buffer); ptr = buffer_ptr(buffer);
buffer_consume(buffer, len); buffer_consume(buffer, len);
if (length_ptr) if (length_ptr)
@ -213,6 +216,16 @@ buffer_get_string_ptr(Buffer *buffer, u_int *length_ptr)
return (ptr); return (ptr);
} }
void *
buffer_get_string_ptr(Buffer *buffer, u_int *length_ptr)
{
void *ret;
if ((ret = buffer_get_string_ptr_ret(buffer, length_ptr)) == NULL)
fatal("buffer_get_string_ptr: buffer error");
return (ret);
}
/* /*
* Stores and arbitrary binary string in the buffer. * Stores and arbitrary binary string in the buffer.
*/ */

View File

@ -1,4 +1,4 @@
/* $OpenBSD: buffer.h,v 1.17 2008/05/08 06:59:01 markus Exp $ */ /* $OpenBSD: buffer.h,v 1.18 2010/01/12 01:36:08 djm Exp $ */
/* /*
* Author: Tatu Ylonen <ylo@cs.hut.fi> * Author: Tatu Ylonen <ylo@cs.hut.fi>
@ -81,6 +81,7 @@ int buffer_get_short_ret(u_short *, Buffer *);
int buffer_get_int_ret(u_int *, Buffer *); int buffer_get_int_ret(u_int *, Buffer *);
int buffer_get_int64_ret(u_int64_t *, Buffer *); int buffer_get_int64_ret(u_int64_t *, Buffer *);
void *buffer_get_string_ret(Buffer *, u_int *); void *buffer_get_string_ret(Buffer *, u_int *);
void *buffer_get_string_ptr_ret(Buffer *, u_int *);
int buffer_get_char_ret(char *, Buffer *); int buffer_get_char_ret(char *, Buffer *);
#endif /* BUFFER_H */ #endif /* BUFFER_H */