diff options
author | jb <jb@FreeBSD.org> | 1998-05-08 05:10:32 +0000 |
---|---|---|
committer | jb <jb@FreeBSD.org> | 1998-05-08 05:10:32 +0000 |
commit | de6ae1a8e253f3d17d6c9d7e1f1ecb9be6309b10 (patch) | |
tree | b296863794c8520027a0608c3db366396cbb3228 /lib | |
parent | ad9978bc4a06f5510c1e190ff7ca74cd66c71f50 (diff) | |
download | FreeBSD-src-de6ae1a8e253f3d17d6c9d7e1f1ecb9be6309b10.zip FreeBSD-src-de6ae1a8e253f3d17d6c9d7e1f1ecb9be6309b10.tar.gz |
Don't assign the va_list variable 'ap' directly to the argtable because
va_list is not a pointer on alpha. Instead, use the va_arg() macro
to return the address that is stored in the argtable.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/libc/stdio/vfprintf.c | 37 |
1 files changed, 18 insertions, 19 deletions
diff --git a/lib/libc/stdio/vfprintf.c b/lib/libc/stdio/vfprintf.c index 5a3a25b..57022e5 100644 --- a/lib/libc/stdio/vfprintf.c +++ b/lib/libc/stdio/vfprintf.c @@ -39,7 +39,7 @@ static char sccsid[] = "@(#)vfprintf.c 8.1 (Berkeley) 6/4/93"; #endif static const char rcsid[] = - "$Id: vfprintf.c,v 1.17 1998/01/04 22:28:47 ache Exp $"; + "$Id: vfprintf.c,v 1.18 1998/04/11 07:40:47 jb Exp $"; #endif /* LIBC_SCCS and not lint */ /* @@ -1105,58 +1105,57 @@ done: (*argtable) [0] = NULL; for (n = 1; n <= tablemax; n++) { - (*argtable) [n] = ap; switch (typetable [n]) { case T_UNUSED: - (void) va_arg (ap, int); + (*argtable) [n] = (void *) &va_arg (ap, int); break; case T_SHORT: - (void) va_arg (ap, int); + (*argtable) [n] = (void *) &va_arg (ap, int); break; case T_U_SHORT: - (void) va_arg (ap, int); + (*argtable) [n] = (void *) &va_arg (ap, int); break; case TP_SHORT: - (void) va_arg (ap, short *); + (*argtable) [n] = (void *) &va_arg (ap, short *); break; case T_INT: - (void) va_arg (ap, int); + (*argtable) [n] = (void *) &va_arg (ap, int); break; case T_U_INT: - (void) va_arg (ap, unsigned int); + (*argtable) [n] = (void *) &va_arg (ap, unsigned int); break; case TP_INT: - (void) va_arg (ap, int *); + (*argtable) [n] = (void *) &va_arg (ap, int *); break; case T_LONG: - (void) va_arg (ap, long); + (*argtable) [n] = (void *) &va_arg (ap, long); break; case T_U_LONG: - (void) va_arg (ap, unsigned long); + (*argtable) [n] = (void *) &va_arg (ap, unsigned long); break; case TP_LONG: - (void) va_arg (ap, long *); + (*argtable) [n] = (void *) &va_arg (ap, long *); break; case T_QUAD: - (void) va_arg (ap, quad_t); + (*argtable) [n] = (void *) &va_arg (ap, quad_t); break; case T_U_QUAD: - (void) va_arg (ap, u_quad_t); + (*argtable) [n] = (void *) &va_arg (ap, u_quad_t); break; case TP_QUAD: - (void) va_arg (ap, quad_t *); + (*argtable) [n] = (void *) &va_arg (ap, quad_t *); break; case T_DOUBLE: - (void) va_arg (ap, double); + (*argtable) [n] = (void *) &va_arg (ap, double); break; case T_LONG_DOUBLE: - (void) va_arg (ap, long double); + (*argtable) [n] = (void *) &va_arg (ap, long double); break; case TP_CHAR: - (void) va_arg (ap, char *); + (*argtable) [n] = (void *) &va_arg (ap, char *); break; case TP_VOID: - (void) va_arg (ap, void *); + (*argtable) [n] = (void *) &va_arg (ap, void *); break; } } |