Merge "Sync with current OpenBSD stdio."

This commit is contained in:
Elliott Hughes
2014-05-03 00:59:06 +00:00
committed by Gerrit Code Review
8 changed files with 35 additions and 26 deletions

View File

@@ -673,6 +673,7 @@ LOCAL_CFLAGS := \
$(libc_common_cflags) \ $(libc_common_cflags) \
-I$(LOCAL_PATH)/upstream-openbsd/android/include \ -I$(LOCAL_PATH)/upstream-openbsd/android/include \
-I$(LOCAL_PATH)/upstream-openbsd/lib/libc/include \ -I$(LOCAL_PATH)/upstream-openbsd/lib/libc/include \
-I$(LOCAL_PATH)/upstream-openbsd/lib/libc/gdtoa/ \
-include openbsd-compat.h -include openbsd-compat.h
LOCAL_CONLYFLAGS := $(libc_common_conlyflags) LOCAL_CONLYFLAGS := $(libc_common_conlyflags)
LOCAL_CPPFLAGS := $(libc_common_cppflags) LOCAL_CPPFLAGS := $(libc_common_cppflags)

View File

@@ -1,4 +1,4 @@
/* $OpenBSD: fgetln.c,v 1.11 2009/11/21 09:53:44 guenther Exp $ */ /* $OpenBSD: fgetln.c,v 1.12 2013/11/12 07:04:06 deraadt Exp $ */
/*- /*-
* Copyright (c) 1990, 1993 * Copyright (c) 1990, 1993
* The Regents of the University of California. All rights reserved. * The Regents of the University of California. All rights reserved.
@@ -43,7 +43,7 @@
* so we add 1 here. * so we add 1 here.
#endif #endif
*/ */
int static int
__slbexpand(FILE *fp, size_t newsize) __slbexpand(FILE *fp, size_t newsize)
{ {
void *p; void *p;

View File

@@ -1,4 +1,4 @@
/* $OpenBSD: fputws.c,v 1.6 2013/04/17 17:40:35 tedu Exp $ */ /* $OpenBSD: fputws.c,v 1.7 2013/11/12 07:04:35 deraadt Exp $ */
/* $NetBSD: fputws.c,v 1.1 2003/03/07 07:11:37 tshiozak Exp $ */ /* $NetBSD: fputws.c,v 1.1 2003/03/07 07:11:37 tshiozak Exp $ */
/*- /*-
@@ -34,8 +34,7 @@
#include <stdio.h> #include <stdio.h>
#include <wchar.h> #include <wchar.h>
#include "local.h" #include "local.h"
#include "fvwrite.h"
wint_t __fputwc_unlock(wchar_t wc, FILE *fp);
int int
fputws(ws, fp) fputws(ws, fp)

View File

@@ -1,4 +1,4 @@
/* $OpenBSD: fread.c,v 1.11 2009/11/21 09:53:44 guenther Exp $ */ /* $OpenBSD: fread.c,v 1.12 2014/05/01 16:40:36 deraadt Exp $ */
/*- /*-
* Copyright (c) 1990, 1993 * Copyright (c) 1990, 1993
* The Regents of the University of California. All rights reserved. * The Regents of the University of California. All rights reserved.
@@ -33,8 +33,12 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <stdint.h>
#include <errno.h>
#include "local.h" #include "local.h"
#define MUL_NO_OVERFLOW (1UL << (sizeof(size_t) * 4))
size_t size_t
fread(void *buf, size_t size, size_t count, FILE *fp) fread(void *buf, size_t size, size_t count, FILE *fp)
{ {
@@ -43,6 +47,16 @@ fread(void *buf, size_t size, size_t count, FILE *fp)
int r; int r;
size_t total; size_t total;
/*
* Extension: Catch integer overflow
*/
if ((size >= MUL_NO_OVERFLOW || count >= MUL_NO_OVERFLOW) &&
size > 0 && SIZE_MAX / size < count) {
errno = EOVERFLOW;
fp->_flags |= __SERR;
return (0);
}
/* /*
* ANSI and SUSv2 require a return value of 0 if size or count are 0. * ANSI and SUSv2 require a return value of 0 if size or count are 0.
*/ */

View File

@@ -1,4 +1,4 @@
/* $OpenBSD: vfprintf.c,v 1.63 2013/03/02 19:40:08 guenther Exp $ */ /* $OpenBSD: vfprintf.c,v 1.65 2014/03/19 05:17:01 guenther Exp $ */
/*- /*-
* Copyright (c) 1990 The Regents of the University of California. * Copyright (c) 1990 The Regents of the University of California.
* All rights reserved. * All rights reserved.
@@ -216,11 +216,10 @@ __wcsconv(wchar_t *wcsarg, int prec)
#include <locale.h> #include <locale.h>
#include <math.h> #include <math.h>
#include "floatio.h" #include "floatio.h"
#include "gdtoa.h"
#define DEFPREC 6 #define DEFPREC 6
extern char *__dtoa(double, int, int, int *, int *, char **);
extern void __freedtoa(char *);
static int exponent(char *, int, int); static int exponent(char *, int, int);
#endif /* FLOATING_POINT */ #endif /* FLOATING_POINT */
@@ -399,7 +398,7 @@ __vfprintf(FILE *fp, const char *fmt0, __va_list ap)
flags&PTRINT ? GETARG(ptrdiff_t) : \ flags&PTRINT ? GETARG(ptrdiff_t) : \
flags&SIZEINT ? GETARG(ssize_t) : \ flags&SIZEINT ? GETARG(ssize_t) : \
flags&SHORTINT ? (short)GETARG(int) : \ flags&SHORTINT ? (short)GETARG(int) : \
flags&CHARINT ? (__signed char)GETARG(int) : \ flags&CHARINT ? (signed char)GETARG(int) : \
GETARG(int))) GETARG(int)))
#define UARG() \ #define UARG() \
((uintmax_t)(flags&MAXINT ? GETARG(uintmax_t) : \ ((uintmax_t)(flags&MAXINT ? GETARG(uintmax_t) : \
@@ -810,7 +809,7 @@ fp_common:
else if (flags & SHORTINT) else if (flags & SHORTINT)
*GETARG(short *) = ret; *GETARG(short *) = ret;
else if (flags & CHARINT) else if (flags & CHARINT)
*GETARG(__signed char *) = ret; *GETARG(signed char *) = ret;
else if (flags & PTRINT) else if (flags & PTRINT)
*GETARG(ptrdiff_t *) = ret; *GETARG(ptrdiff_t *) = ret;
else if (flags & SIZEINT) else if (flags & SIZEINT)

View File

@@ -1,4 +1,4 @@
/* $OpenBSD: vfscanf.c,v 1.30 2013/04/17 17:40:35 tedu Exp $ */ /* $OpenBSD: vfscanf.c,v 1.31 2014/03/19 05:17:01 guenther Exp $ */
/*- /*-
* Copyright (c) 1990, 1993 * Copyright (c) 1990, 1993
* The Regents of the University of California. All rights reserved. * The Regents of the University of California. All rights reserved.
@@ -273,7 +273,7 @@ literal:
if (flags & SUPPRESS) if (flags & SUPPRESS)
continue; continue;
if (flags & SHORTSHORT) if (flags & SHORTSHORT)
*va_arg(ap, __signed char *) = nread; *va_arg(ap, signed char *) = nread;
else if (flags & SHORT) else if (flags & SHORT)
*va_arg(ap, short *) = nread; *va_arg(ap, short *) = nread;
else if (flags & LONG) else if (flags & LONG)
@@ -749,7 +749,7 @@ literal:
else if (flags & SHORT) else if (flags & SHORT)
*va_arg(ap, short *) = res; *va_arg(ap, short *) = res;
else if (flags & SHORTSHORT) else if (flags & SHORTSHORT)
*va_arg(ap, __signed char *) = res; *va_arg(ap, signed char *) = res;
else else
*va_arg(ap, int *) = res; *va_arg(ap, int *) = res;
nassigned++; nassigned++;

View File

@@ -1,4 +1,4 @@
/* $OpenBSD: vfwprintf.c,v 1.6 2013/04/17 17:40:35 tedu Exp $ */ /* $OpenBSD: vfwprintf.c,v 1.9 2014/03/19 05:17:01 guenther Exp $ */
/*- /*-
* Copyright (c) 1990 The Regents of the University of California. * Copyright (c) 1990 The Regents of the University of California.
* All rights reserved. * All rights reserved.
@@ -54,8 +54,6 @@
#include "local.h" #include "local.h"
#include "fvwrite.h" #include "fvwrite.h"
wint_t __fputwc_unlock(wchar_t wc, FILE *fp);
union arg { union arg {
int intarg; int intarg;
unsigned int uintarg; unsigned int uintarg;
@@ -235,11 +233,10 @@ __mbsconv(char *mbsarg, int prec)
#include <locale.h> #include <locale.h>
#include <math.h> #include <math.h>
#include "floatio.h" #include "floatio.h"
#include "gdtoa.h"
#define DEFPREC 6 #define DEFPREC 6
extern char *__dtoa(double, int, int, int *, int *, char **);
extern void __freedtoa(char *);
static int exponent(wchar_t *, int, int); static int exponent(wchar_t *, int, int);
#endif /* FLOATING_POINT */ #endif /* FLOATING_POINT */
@@ -392,7 +389,7 @@ __vfwprintf(FILE * __restrict fp, const wchar_t * __restrict fmt0, __va_list ap)
flags&PTRINT ? GETARG(ptrdiff_t) : \ flags&PTRINT ? GETARG(ptrdiff_t) : \
flags&SIZEINT ? GETARG(ssize_t) : \ flags&SIZEINT ? GETARG(ssize_t) : \
flags&SHORTINT ? (short)GETARG(int) : \ flags&SHORTINT ? (short)GETARG(int) : \
flags&CHARINT ? (__signed char)GETARG(int) : \ flags&CHARINT ? (signed char)GETARG(int) : \
GETARG(int))) GETARG(int)))
#define UARG() \ #define UARG() \
((uintmax_t)(flags&MAXINT ? GETARG(uintmax_t) : \ ((uintmax_t)(flags&MAXINT ? GETARG(uintmax_t) : \
@@ -795,7 +792,7 @@ fp_common:
else if (flags & SHORTINT) else if (flags & SHORTINT)
*GETARG(short *) = ret; *GETARG(short *) = ret;
else if (flags & CHARINT) else if (flags & CHARINT)
*GETARG(__signed char *) = ret; *GETARG(signed char *) = ret;
else if (flags & PTRINT) else if (flags & PTRINT)
*GETARG(ptrdiff_t *) = ret; *GETARG(ptrdiff_t *) = ret;
else if (flags & SIZEINT) else if (flags & SIZEINT)

View File

@@ -1,4 +1,4 @@
/* $OpenBSD: vfwscanf.c,v 1.2 2012/01/18 17:23:11 chl Exp $ */ /* $OpenBSD: vfwscanf.c,v 1.4 2014/03/19 05:17:01 guenther Exp $ */
/*- /*-
* Copyright (c) 1990, 1993 * Copyright (c) 1990, 1993
* The Regents of the University of California. All rights reserved. * The Regents of the University of California. All rights reserved.
@@ -31,7 +31,6 @@
* SUCH DAMAGE. * SUCH DAMAGE.
*/ */
#include <ctype.h>
#include <inttypes.h> #include <inttypes.h>
#include <limits.h> #include <limits.h>
#include <locale.h> #include <locale.h>
@@ -300,7 +299,7 @@ literal:
if (flags & SUPPRESS) if (flags & SUPPRESS)
continue; continue;
if (flags & SHORTSHORT) if (flags & SHORTSHORT)
*va_arg(ap, __signed char *) = nread; *va_arg(ap, signed char *) = nread;
else if (flags & SHORT) else if (flags & SHORT)
*va_arg(ap, short *) = nread; *va_arg(ap, short *) = nread;
else if (flags & LONG) else if (flags & LONG)
@@ -324,7 +323,7 @@ literal:
return (EOF); return (EOF);
default: /* compat */ default: /* compat */
if (isupper(c)) if (iswupper(c))
flags |= LONG; flags |= LONG;
c = CT_INT; c = CT_INT;
base = 10; base = 10;
@@ -672,7 +671,7 @@ literal:
else if (flags & SHORT) else if (flags & SHORT)
*va_arg(ap, short *) = res; *va_arg(ap, short *) = res;
else if (flags & SHORTSHORT) else if (flags & SHORTSHORT)
*va_arg(ap, __signed char *) = res; *va_arg(ap, signed char *) = res;
else else
*va_arg(ap, int *) = res; *va_arg(ap, int *) = res;
nassigned++; nassigned++;