summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--arch/i386/bits/stdarg.h9
-rw-r--r--include/stdarg.h16
2 files changed, 10 insertions, 15 deletions
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 <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
}