diff options
Diffstat (limited to 'sysdeps/x86_64/multiarch/memset-avx512-unaligned-erms-no-vzeroupper.S')
-rw-r--r-- | sysdeps/x86_64/multiarch/memset-avx512-unaligned-erms-no-vzeroupper.S | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/sysdeps/x86_64/multiarch/memset-avx512-unaligned-erms-no-vzeroupper.S b/sysdeps/x86_64/multiarch/memset-avx512-unaligned-erms-no-vzeroupper.S new file mode 100644 index 0000000000..db246306b5 --- /dev/null +++ b/sysdeps/x86_64/multiarch/memset-avx512-unaligned-erms-no-vzeroupper.S @@ -0,0 +1,19 @@ +#ifdef HAVE_AVX512_ASM_SUPPORT +# define VEC_SIZE 64 +# define VEC(i) zmm##i +# define VMOVU vmovdqu64 +# define VMOVA vmovdqa64 +# define VZEROUPPER +# define VZEROUPPER_SHORT_RETURN rep + +# define VDUP_TO_VEC0_AND_SET_RETURN(d, r) \ + vmovd d, %xmm0; \ + movq r, %rax; \ + vpbroadcastb %xmm0, %xmm0; \ + vpbroadcastq %xmm0, %zmm0 + +# define SECTION(p) p##.avx512 +# define MEMSET_SYMBOL(p,s) p##_avx512_no_vzeroupper_##s + +# include "memset-vec-unaligned-erms.S" +#endif |