diff --git a/libc/src/string/memory_utils/memset_utils.h b/libc/src/string/memory_utils/memset_utils.h --- a/libc/src/string/memory_utils/memset_utils.h +++ b/libc/src/string/memory_utils/memset_utils.h @@ -49,28 +49,33 @@ // superior for sizes that mattered. inline static void GeneralPurposeMemset(char *dst, unsigned char value, size_t count) { +#if defined(__i386__) || defined(__x86_64__) + using namespace ::__llvm_libc::x86; +#else + using namespace ::__llvm_libc::scalar; +#endif + if (count == 0) return; if (count == 1) - return SplatSet(dst, value); + return SplatSet<_1>(dst, value); if (count == 2) - return SplatSet(dst, value); + return SplatSet<_2>(dst, value); if (count == 3) - return SplatSet(dst, value); + return SplatSet<_3>(dst, value); if (count == 4) - return SplatSet(dst, value); + return SplatSet<_4>(dst, value); if (count <= 8) - return SplatSet>(dst, value, count); + return SplatSet>(dst, value, count); if (count <= 16) - return SplatSet>(dst, value, count); + return SplatSet>(dst, value, count); if (count <= 32) - return SplatSet>(dst, value, count); + return SplatSet>(dst, value, count); if (count <= 64) - return SplatSet>(dst, value, count); + return SplatSet>(dst, value, count); if (count <= 128) - return SplatSet>(dst, value, count); - return SplatSet::Then>>( - dst, value, count); + return SplatSet>(dst, value, count); + return SplatSet::Then>>(dst, value, count); } } // namespace __llvm_libc