[libc-commits] [libc] [libc] memmove optimizations (PR #70043)
via libc-commits
libc-commits at lists.llvm.org
Thu Oct 26 02:18:36 PDT 2023
github-actions[bot] wrote:
<!--LLVM CODE FORMAT COMMENT: {clang-format}-->
:warning: C/C++ code formatter, clang-format found issues in your code. :warning:
<details>
<summary>
You can test this locally with the following command:
</summary>
``````````bash
git-clang-format --diff 274ce8895b29e8be047a68629efda2e9d3ad1f01 65dfb6ddb602750063aa73bc7c15f6da55a2cc1c -- libc/src/string/memmove.cpp libc/src/string/memory_utils/inline_memmove.h libc/src/string/memory_utils/x86_64/inline_memmove.h
``````````
</details>
<details>
<summary>
View the diff from clang-format here.
</summary>
``````````diff
diff --git a/libc/src/string/memory_utils/inline_memmove.h b/libc/src/string/memory_utils/inline_memmove.h
index f7d7aa415..30c2c3ddb 100644
--- a/libc/src/string/memory_utils/inline_memmove.h
+++ b/libc/src/string/memory_utils/inline_memmove.h
@@ -13,23 +13,30 @@
#if defined(LIBC_TARGET_ARCH_IS_X86)
#include "src/string/memory_utils/x86_64/inline_memmove.h"
-#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE inline_memmove_small_size_x86
-#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP inline_memmove_follow_up_x86
+#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE \
+ inline_memmove_small_size_x86
+#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP \
+ inline_memmove_follow_up_x86
#elif defined(LIBC_TARGET_ARCH_IS_AARCH64)
#include "src/string/memory_utils/aarch64/inline_memmove.h"
-#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE inline_memmove_no_small_size
+#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE \
+ inline_memmove_no_small_size
#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP inline_memmove_aarch64
#elif defined(LIBC_TARGET_ARCH_IS_ANY_RISCV)
#include "src/string/memory_utils/riscv/inline_memmove.h"
-#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE inline_memmove_no_small_size
+#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE \
+ inline_memmove_no_small_size
#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP inline_memmove_riscv
#elif defined(LIBC_TARGET_ARCH_IS_ARM)
#include "src/string/memory_utils/generic/byte_per_byte.h"
-#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE inline_memmove_no_small_size
-#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP inline_memmove_byte_per_byte
+#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE \
+ inline_memmove_no_small_size
+#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP \
+ inline_memmove_byte_per_byte
#elif defined(LIBC_TARGET_ARCH_IS_GPU)
#include "src/string/memory_utils/generic/builtin.h"
-#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE inline_memmove_no_small_size
+#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE \
+ inline_memmove_no_small_size
#define LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP inline_memmove_builtin
#else
#error "Unsupported architecture"
@@ -37,16 +44,21 @@
namespace LIBC_NAMESPACE {
-LIBC_INLINE constexpr bool inline_memmove_no_small_size(void *, const void *, size_t) {
+LIBC_INLINE constexpr bool inline_memmove_no_small_size(void *, const void *,
+ size_t) {
return false;
}
-LIBC_INLINE bool inline_memmove_small_size(void *dst, const void *src, size_t count) {
- return LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE(reinterpret_cast<Ptr>(dst), reinterpret_cast<CPtr>(src), count);
+LIBC_INLINE bool inline_memmove_small_size(void *dst, const void *src,
+ size_t count) {
+ return LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_SMALL_SIZE(
+ reinterpret_cast<Ptr>(dst), reinterpret_cast<CPtr>(src), count);
}
-LIBC_INLINE void inline_memmove_follow_up(void *dst, const void *src, size_t count) {
- LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP(reinterpret_cast<Ptr>(dst), reinterpret_cast<CPtr>(src), count);
+LIBC_INLINE void inline_memmove_follow_up(void *dst, const void *src,
+ size_t count) {
+ LIBC_SRC_STRING_MEMORY_UTILS_MEMMOVE_FOLLOW_UP(
+ reinterpret_cast<Ptr>(dst), reinterpret_cast<CPtr>(src), count);
}
LIBC_INLINE void inline_memmove(void *dst, const void *src, size_t count) {
diff --git a/libc/src/string/memory_utils/x86_64/inline_memmove.h b/libc/src/string/memory_utils/x86_64/inline_memmove.h
index d097a498d..879b36eaa 100644
--- a/libc/src/string/memory_utils/x86_64/inline_memmove.h
+++ b/libc/src/string/memory_utils/x86_64/inline_memmove.h
@@ -18,7 +18,8 @@
namespace LIBC_NAMESPACE {
-LIBC_INLINE bool inline_memmove_small_size_x86(Ptr dst, CPtr src, size_t count) {
+LIBC_INLINE bool inline_memmove_small_size_x86(Ptr dst, CPtr src,
+ size_t count) {
#if defined(__AVX512F__)
constexpr size_t vector_size = 64;
using uint128_t = generic_v128;
``````````
</details>
https://github.com/llvm/llvm-project/pull/70043
More information about the libc-commits
mailing list