1 /* { dg-require-effective-target vect_int } */
8 #define SIGNEDNESS unsigned
14 void __attribute__ ((noipa
))
15 f (SIGNEDNESS
char *restrict a
, SIGNEDNESS
char *restrict b
,
16 SIGNEDNESS
char *restrict c
)
18 for (__INTPTR_TYPE__ i
= 0; i
< N
; ++i
)
19 a
[i
] = (b
[i
] + c
[i
] + BIAS
) >> 1;
22 #define BASE1 ((SIGNEDNESS int) -1 < 0 ? -126 : 4)
23 #define BASE2 ((SIGNEDNESS int) -1 < 0 ? -101 : 26)
30 SIGNEDNESS
char a
[N
], b
[N
], c
[N
];
31 for (int i
= 0; i
< N
; ++i
)
35 asm volatile ("" ::: "memory");
38 for (int i
= 0; i
< N
; ++i
)
39 if (a
[i
] != ((BASE1
+ BASE2
+ i
* 9 + BIAS
) >> 1))
44 /* { dg-final { scan-tree-dump "vect_recog_average_pattern: detected" "vect" } } */
45 /* { dg-final { scan-tree-dump {\.AVG_FLOOR} "vect" { target vect_avg_qi } } } */
46 /* { dg-final { scan-tree-dump-not {vector\([^\n]*short} "vect" { target vect_avg_qi } } } */
47 /* { dg-final { scan-tree-dump-times "vectorized 1 loop" 1 "vect" { target vect_avg_qi } } } */