diff --git a/libc/src/__support/common.h b/libc/src/__support/common.h index 6d1110dbd27de..300d2bc8b2a4f 100644 --- a/libc/src/__support/common.h +++ b/libc/src/__support/common.h @@ -18,21 +18,25 @@ // GPU targets do not support aliasing. #if defined(LIBC_COPT_PUBLIC_PACKAGING) && defined(LIBC_TARGET_ARCH_IS_GPU) -#define LLVM_LIBC_FUNCTION(type, name, arglist) \ +#define LLVM_LIBC_FUNCTION_IMPL(type, name, arglist) \ LLVM_LIBC_FUNCTION_ATTR decltype(__llvm_libc::name) \ __##name##_impl__ __asm__(#name); \ type __##name##_impl__ arglist // MacOS needs to be excluded because it does not support aliasing. #elif defined(LIBC_COPT_PUBLIC_PACKAGING) && (!defined(__APPLE__)) -#define LLVM_LIBC_FUNCTION(type, name, arglist) \ +#define LLVM_LIBC_FUNCTION_IMPL(type, name, arglist) \ LLVM_LIBC_FUNCTION_ATTR decltype(__llvm_libc::name) \ __##name##_impl__ __asm__(#name); \ decltype(__llvm_libc::name) name [[gnu::alias(#name)]]; \ type __##name##_impl__ arglist #else -#define LLVM_LIBC_FUNCTION(type, name, arglist) type name arglist +#define LLVM_LIBC_FUNCTION_IMPL(type, name, arglist) type name arglist #endif +// This extra layer of macro allows `name` to be a macro to rename a function. +#define LLVM_LIBC_FUNCTION(type, name, arglist) \ + LLVM_LIBC_FUNCTION_IMPL(type, name, arglist) + namespace __llvm_libc { namespace internal { constexpr bool same_string(char const *lhs, char const *rhs) {