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,0284148813) Reviewed By: courbet Differential Revision: https://reviews.llvm.org/D136595
21 lines
698 B
C++
21 lines
698 B
C++
//===-- Implementation of memset ------------------------------------------===//
|
|
//
|
|
// 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/memset.h"
|
|
#include "src/__support/common.h"
|
|
#include "src/string/memory_utils/memset_implementations.h"
|
|
|
|
namespace __llvm_libc {
|
|
|
|
LLVM_LIBC_FUNCTION(void *, memset, (void *dst, int value, size_t count)) {
|
|
inline_memset(dst, static_cast<uint8_t>(value), count);
|
|
return dst;
|
|
}
|
|
|
|
} // namespace __llvm_libc
|