[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