From: Rich Felker Date: Tue, 15 Feb 2011 10:06:15 +0000 (-0500) Subject: split off arch-specific stdarg.h stuff X-Git-Tag: v0.6.0~37 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=13a026bd79f0024d57b7edf8305d625599d10810;p=oweals%2Fmusl.git split off arch-specific stdarg.h stuff --- diff --git a/arch/i386/bits/stdarg.h b/arch/i386/bits/stdarg.h new file mode 100644 index 00000000..6b1830d2 --- /dev/null +++ b/arch/i386/bits/stdarg.h @@ -0,0 +1,9 @@ +#define __VA_ALIGNED_SIZE(x) ((sizeof(x) + sizeof(int) - 1) & ~(sizeof(int) - 1)) + +#define va_start(ap, last) ((ap) = (void *)(((char *)&(last)) + __VA_ALIGNED_SIZE(last))) +#define va_end(ap) ((void)0) +#define va_copy(dest, src) ((dest) = (src)) + +#define va_arg(ap, type) \ + ( ((ap) = (va_list)((char *)(ap) + __VA_ALIGNED_SIZE(type))), \ + *(type *)(void *)((char *)(ap) - __VA_ALIGNED_SIZE(type)) ) diff --git a/include/stdarg.h b/include/stdarg.h index cb18778b..2e18e5f5 100644 --- a/include/stdarg.h +++ b/include/stdarg.h @@ -9,21 +9,7 @@ extern "C" { #include -#define __VA_ALIGNED_SIZE(x) ((sizeof(x) + sizeof(int) - 1) & ~(sizeof(int) - 1)) - -#define va_start(ap, last) ((ap) = (void *)(((char *)&(last)) + __VA_ALIGNED_SIZE(last))) -#define va_end(ap) ((void)0) -#define va_copy(dest, src) ((dest) = (src)) - -#if 0 -#define va_arg(ap, type) \ - ( ((ap) = (va_list)((char *)(ap) + sizeof(type))), \ - *(type *)(void *)((char *)(ap) - sizeof(type)) ) -#endif - -#define va_arg(ap, type) \ - ( ((ap) = (va_list)((char *)(ap) + __VA_ALIGNED_SIZE(type))), \ - *(type *)(void *)((char *)(ap) - __VA_ALIGNED_SIZE(type)) ) +#include #ifdef __cplusplus }