OSDN Git Service

remove legacy i386 fallback stdarg implementation and framework
authorRich Felker <dalias@aerifal.cx>
Thu, 15 Dec 2016 17:18:24 +0000 (12:18 -0500)
committerRich Felker <dalias@aerifal.cx>
Thu, 15 Dec 2016 17:18:24 +0000 (12:18 -0500)
this has been slated for removal for a long time. there is
fundamentally no way to implement stdarg without compiler assistance;
any attempt to do so has serious undefined behavior; its working
depends not just (as a common misconception goes) on ABI, but also on
assumptions about compiler code generation internal to a translation
unit, which is not subject to external ABI constraints.

arch/generic/bits/stdarg.h [deleted file]
arch/i386/bits/stdarg.h [deleted file]
include/stdarg.h

diff --git a/arch/generic/bits/stdarg.h b/arch/generic/bits/stdarg.h
deleted file mode 100644 (file)
index fde3781..0000000
+++ /dev/null
@@ -1,4 +0,0 @@
-#define va_start(v,l)   __builtin_va_start(v,l)
-#define va_end(v)       __builtin_va_end(v)
-#define va_arg(v,l)     __builtin_va_arg(v,l)
-#define va_copy(d,s)    __builtin_va_copy(d,s)
diff --git a/arch/i386/bits/stdarg.h b/arch/i386/bits/stdarg.h
deleted file mode 100644 (file)
index 6b1830d..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-#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 60d4e2a..3256f80 100644 (file)
@@ -9,14 +9,10 @@ extern "C" {
 
 #include <bits/alltypes.h>
 
-#if __GNUC__ >= 3
 #define va_start(v,l)   __builtin_va_start(v,l)
 #define va_end(v)       __builtin_va_end(v)
 #define va_arg(v,l)     __builtin_va_arg(v,l)
 #define va_copy(d,s)    __builtin_va_copy(d,s)
-#else
-#include <bits/stdarg.h>
-#endif
 
 #ifdef __cplusplus
 }