1 /* PR target/98461 */
2 /* { dg-do compile } */
3 /* { dg-options "-O2 -mavx2 -masm=att" } */
4 /* { dg-final { scan-assembler-times "\tvpmovmskb\t" 6 } } */
5 /* { dg-final { scan-assembler-times "\tnotl\t" 6 } } */
6 /* { dg-final { scan-assembler-not "\tvpcmpeq" } } */
7 /* { dg-final { scan-assembler-not "\tvpxor" } } */
8 /* { dg-final { scan-assembler-not "\tvpandn" } } */
9 
10 #include <x86intrin.h>
11 
12 int
f1(__m256i x)13 f1 (__m256i x)
14 {
15   return ~_mm256_movemask_epi8 (x);
16 }
17 
18 int
f2(__m256i x)19 f2 (__m256i x)
20 {
21   return _mm256_movemask_epi8 (_mm256_andnot_si256 (x, _mm256_set1_epi8 (255)));
22 }
23 
24 int
f3(__v32qi x)25 f3 (__v32qi x)
26 {
27   x ^= (__v32qi) { -1, -1, -1, -1, -1, -1, -1, -1,
28 		   -1, -1, -1, -1, -1, -1, -1, -1,
29 		   -1, -1, -1, -1, -1, -1, -1, -1,
30 		   -1, -1, -1, -1, -1, -1, -1, -1 };
31   return _mm256_movemask_epi8 ((__m256i) x);
32 }
33 
34 long
f4(__m256i x)35 f4 (__m256i x)
36 {
37   return (unsigned) ~_mm256_movemask_epi8 (x);
38 }
39 
40 long
f5(__m256i x)41 f5 (__m256i x)
42 {
43   return (unsigned) _mm256_movemask_epi8 (_mm256_andnot_si256 (x, _mm256_set1_epi8 (255)));
44 }
45 
46 long
f6(__v32qi x)47 f6 (__v32qi x)
48 {
49   x ^= (__v32qi) { -1, -1, -1, -1, -1, -1, -1, -1,
50 		   -1, -1, -1, -1, -1, -1, -1, -1,
51 		   -1, -1, -1, -1, -1, -1, -1, -1,
52 		   -1, -1, -1, -1, -1, -1, -1, -1 };
53   return (unsigned) _mm256_movemask_epi8 ((__m256i) x);
54 }
55