From: Stan Shebs Date: Fri, 12 Nov 2021 14:48:03 +0000 (-0800) Subject: Use a better workaround for clang lack of _builtin_va_arg_pack X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=b0d12dcb635744a4fa0ebd13b6e5743d67da1046;p=thirdparty%2Fglibc.git Use a better workaround for clang lack of _builtin_va_arg_pack --- diff --git a/sysdeps/generic/ldsodefs.h b/sysdeps/generic/ldsodefs.h index 0495f85e845..8759f6e5616 100644 --- a/sysdeps/generic/ldsodefs.h +++ b/sysdeps/generic/ldsodefs.h @@ -744,15 +744,26 @@ extern void _dl_dprintf (int fd, const char *fmt, ...) __attribute__ ((__format__ (__printf__, 2, 3))) attribute_hidden; #else +#if defined(__clang__) +#include +#endif __attribute__ ((always_inline, __format__ (__printf__, 2, 3))) static inline void _dl_dprintf (int fd, const char *fmt, ...) { - /* Use local declaration to avoid includign . */ - extern int __dprintf(int fd, const char *format, ...) attribute_hidden; #if defined(__clang__) - __dprintf (fd, fmt); + /* In the absence of __builtin_va_arg_pack, use varargs macros to construct a + direct call to the stdio function that __dprintf eventually gets to. This + is not a robust hack, will break if stdio changes much. */ + extern int _IO_vdprintf (int d, const char *format, va_list arg); + va_list arg; + + va_start (arg, fmt); + _IO_vdprintf (fd, fmt, arg); + va_end (arg); #else + /* Use local declaration to avoid includign . */ + extern int __dprintf(int fd, const char *format, ...) attribute_hidden; __dprintf (fd, fmt, __builtin_va_arg_pack ()); #endif }