[libc-commits] [libc] [libc] implement `memalignment` (PR #132493)
Mohamed Emad via libc-commits
libc-commits at lists.llvm.org
Sun Mar 23 10:32:27 PDT 2025
================
@@ -0,0 +1,15 @@
+#include "src/stdlib/memalignment.h"
+#include "src/__support/macros/config.h"
+#include "src/__support/CPP/bit.h"
+namespace LIBC_NAMESPACE_DECL {
+
+LLVM_LIBC_FUNCTION(size_t, memalignment, (const void *p)) {
+ if (p == nullptr)
+ return 0;
+
+ uintptr_t addr = reinterpret_cast<uintptr_t>(p);
+
+ return 1 << cpp::countr_zero(addr);
----------------
hulxv wrote:
I am confused now, should I use the current approach or the previous (`addr & (~addr + 1)`)?
https://github.com/llvm/llvm-project/pull/132493
More information about the libc-commits
mailing list