The new framework makes it explicit which processor feature is being used and allows for easier per platform customization: - ARM cpu now uses trivial implementations to reduce code size. - Memcmp, Bcmp and Memmove have been optimized for x86 - Bcmp has been optimized for aarch64. This is a reland of https://reviews.llvm.org/D135134 (b3f1d58, 028414881381) Reviewed By: courbet Differential Revision: https://reviews.llvm.org/D136595
25 lines
812 B
C++
25 lines
812 B
C++
//===-- Implementation of mempcpy ----------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "src/string/mempcpy.h"
|
|
#include "src/string/memory_utils/memcpy_implementations.h"
|
|
|
|
#include "src/__support/common.h"
|
|
#include <stddef.h> // For size_t.
|
|
|
|
namespace __llvm_libc {
|
|
|
|
LLVM_LIBC_FUNCTION(void *, mempcpy,
|
|
(void *__restrict dst, const void *__restrict src,
|
|
size_t count)) {
|
|
inline_memcpy(dst, src, count);
|
|
return reinterpret_cast<char *>(dst) + count;
|
|
}
|
|
|
|
} // namespace __llvm_libc
|