upstream commit

Fix two rare edge cases: 1. If vasprintf() returns < 0,
 do not access a NULL pointer in snmprintf(), and do not free() the pointer
 returned from vasprintf() because on some systems other than OpenBSD, it
 might be a bogus pointer. 2. If vasprintf() returns == 0, return 0 and ""
 rather than -1 and NULL.

Besides, free(dst) is pointless after failure (not a bug).

One half OK martijn@, the other half OK deraadt@;
committing quickly before people get hurt.

Upstream-Regress-ID: b164f20923812c9bac69856dbc1385eb1522cba4
This commit is contained in:
schwarze@openbsd.org 2016-05-30 12:05:56 +00:00 committed by Damien Miller
parent 016881eb33
commit 75f0844b4f
1 changed files with 20 additions and 1 deletions

View File

@ -1,4 +1,4 @@
/* $OpenBSD: tests.c,v 1.1 2016/05/26 19:14:25 schwarze Exp $ */ /* $OpenBSD: tests.c,v 1.2 2016/05/30 12:05:56 schwarze Exp $ */
/* /*
* Regress test for the utf8.h *mprintf() API * Regress test for the utf8.h *mprintf() API
* *
@ -13,8 +13,24 @@
#include "utf8.h" #include "utf8.h"
void badarg(void);
void one(const char *, const char *, int, int, int, const char *); void one(const char *, const char *, int, int, int, const char *);
void
badarg(void)
{
char buf[16];
int len, width;
width = 1;
TEST_START("utf8_badarg");
len = snmprintf(buf, sizeof(buf), &width, "\377");
ASSERT_INT_EQ(len, -1);
ASSERT_STRING_EQ(buf, "");
ASSERT_INT_EQ(width, 0);
TEST_DONE();
}
void void
one(const char *name, const char *mbs, int width, one(const char *name, const char *mbs, int width,
int wantwidth, int wantlen, const char *wants) int wantwidth, int wantlen, const char *wants)
@ -46,6 +62,9 @@ tests(void)
ASSERT_PTR_NE(loc, NULL); ASSERT_PTR_NE(loc, NULL);
TEST_DONE(); TEST_DONE();
badarg();
one("null", NULL, 8, 6, 6, "(null)");
one("empty", "", 2, 0, 0, "");
one("ascii", "x", -2, -2, -2, "x"); one("ascii", "x", -2, -2, -2, "x");
one("newline", "a\nb", -2, -2, -2, "a\nb"); one("newline", "a\nb", -2, -2, -2, "a\nb");
one("cr", "a\rb", -2, -2, -2, "a\rb"); one("cr", "a\rb", -2, -2, -2, "a\rb");