about summary refs log tree commit diff
path: root/sysdeps/x86_64/multiarch/memset-evex-unaligned-erms.S
blob: 1f03b26bf86592550ab52d9dea9994b17c7bd6f4 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include <isa-level.h>

#if ISA_SHOULD_BUILD (4)

# define USE_WITH_EVEX	1

# include "x86-evex256-vecs.h"

# define MEMSET_SET_VEC0_AND_SET_RETURN(d, r) \
  vpbroadcastb d, %VMM(0); \
  movq r, %rax

# define WMEMSET_SET_VEC0_AND_SET_RETURN(d, r) \
  vpbroadcastd d, %VMM(0); \
  movq r, %rax

# define MEMSET_VDUP_TO_VEC0_HIGH()
# define MEMSET_VDUP_TO_VEC0_LOW()

# define WMEMSET_VDUP_TO_VEC0_HIGH()
# define WMEMSET_VDUP_TO_VEC0_LOW()

#ifndef MEMSET_SYMBOL
# define MEMSET_SYMBOL(p,s)	p##_evex_##s
#endif
#ifndef WMEMSET_SYMBOL
# define WMEMSET_SYMBOL(p,s)	p##_evex_##s
#endif


# define USE_LESS_VEC_MASK_STORE	1
# include "memset-vec-unaligned-erms.S"
#endif