split off arch-specific stdarg.h stuff
authorRich Felker <dalias@aerifal.cx>
Tue, 15 Feb 2011 10:06:15 +0000 (05:06 -0500)
committerRich Felker <dalias@aerifal.cx>
Tue, 15 Feb 2011 10:06:15 +0000 (05:06 -0500)
arch/i386/bits/stdarg.h [new file with mode: 0644]
include/stdarg.h

diff --git a/arch/i386/bits/stdarg.h b/arch/i386/bits/stdarg.h
new file mode 100644 (file)
index 0000000..6b1830d
--- /dev/null
@@ -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)) )
index cb18778ba154d61be3e35cf2c495cecbb9a799ed..2e18e5f5db468f7f651128ec8748cbe98b4a1cad 100644 (file)
@@ -9,21 +9,7 @@ extern "C" {
 
 #include <bits/alltypes.h>
 
-#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 <bits/stdarg.h>
 
 #ifdef __cplusplus
 }