[libc-commits] [libc] [libc] Proof of concept of aliasing long double math functions. (PR #132627)
Michael Jones via libc-commits
libc-commits at lists.llvm.org
Mon Mar 24 13:52:43 PDT 2025
================
@@ -37,21 +37,47 @@
#define LLVM_LIBC_ATTR(name) EXPAND_THEN_SECOND(LLVM_LIBC_FUNCTION_ATTR_##name)
-// MacOS needs to be excluded because it does not support aliasing.
-#if defined(LIBC_COPT_PUBLIC_PACKAGING) && (!defined(__APPLE__))
-#define LLVM_LIBC_FUNCTION_IMPL(type, name, arglist) \
+// MacOS needs to be excluded because it does not support [[gnu::aliasing]].
+#ifndef __APPLE__
+
+#if defined(LIBC_COPT_PUBLIC_PACKAGING)
+#define LLVM_LIBC_FUNCTION(type, name, arglist) \
LLVM_LIBC_ATTR(name) \
LLVM_LIBC_FUNCTION_ATTR decltype(LIBC_NAMESPACE::name) \
- __##name##_impl__ __asm__(#name); \
+ __##name##_impl__ asm(#name); \
decltype(LIBC_NAMESPACE::name) name [[gnu::alias(#name)]]; \
type __##name##_impl__ arglist
-#else
-#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_ALIASING_FUNCTION(name, func) \
+ namespace LIBC_NAMESPACE_DECL { \
----------------
michaelrj-google wrote:
I'd argue that having two `#ifdef`s is more readable if it means that we can have:
```
#if ...
#include "copysignl.h"
#endif
namespace LIBC_NAMESPACE_DECL{
<normal stuff>
#if ...
LLVM_LIBC_ALIASING_FUNCTION(copysignl, copysignf128);
#endif
}
```
That way it's clear what is and isn't in the namespace and you don't have to repeat the namespace
https://github.com/llvm/llvm-project/pull/132627
More information about the libc-commits
mailing list