From: binhdvo Date: Tue, 14 Dec 2021 20:53:50 +0000 (-0500) Subject: Fix performance degradation with -m32 (#2926) X-Git-Tag: v1.5.1~1^2~15 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=64205b7832fa0b4433214e26c294545b4c962834;p=thirdparty%2Fzstd.git Fix performance degradation with -m32 (#2926) --- diff --git a/lib/common/zstd_internal.h b/lib/common/zstd_internal.h index 9073df422..3dc14bb14 100644 --- a/lib/common/zstd_internal.h +++ b/lib/common/zstd_internal.h @@ -188,8 +188,13 @@ static void ZSTD_copy16(void* dst, const void* src) { vst1q_u8((uint8_t*)dst, vld1q_u8((const uint8_t*)src)); #elif defined(ZSTD_ARCH_X86_SSE2) _mm_storeu_si128((__m128i*)dst, _mm_loadu_si128((const __m128i*)src)); -#else +#elif defined(__clang__) ZSTD_memmove(dst, src, 16); +#else + /* ZSTD_memmove is not inlined properly by gcc */ + BYTE copy16_buf[16]; + ZSTD_memcpy(copy16_buf, src, 16); + ZSTD_memcpy(dst, copy16_buf, 16); #endif } #define COPY16(d,s) { ZSTD_copy16(d,s); d+=16; s+=16; }