i386: Adjust rtx cost for imulq and imulw [PR115749]
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / no-vfa-vect-depend-2.c
blob25a3409ae5e2ebdb6f7ebabc7974cd49ac7b7d47
1 /* { dg-require-effective-target vect_int } */
3 #include <stdarg.h>
4 #include "tree-vect.h"
6 #define N 17
8 int ia[N] = {48,45,42,39,36,33,30,27,24,21,18,15,12,9,6,3,0};
9 int ib[N] = {48,45,42,39,36,33,30,27,24,21,18,15,12,9,6,3,0};
10 int res[N] = {48,192,180,168,156,144,132,120,108,96,84,72,60,48,36,24,12};
12 __attribute__ ((noinline))
13 int main1 ()
15 int i;
17 /* Not vectorizable due to data dependence: dependence distance 1. */
18 for (i = N - 2; i >= 0; i--)
20 ia[i] = ia[i+1] * 4;
23 /* check results: */
24 #pragma GCC novector
25 for (i = 0; i < N; i++)
27 if (ia[i] != 0)
28 abort ();
31 /* Vectorizable. Dependence distance -1. */
32 for (i = N - 2; i >= 0; i--)
34 ib[i+1] = ib[i] * 4;
37 /* check results: */
38 #pragma GCC novector
39 for (i = 0; i < N; i++)
41 if (ib[i] != res[i])
42 abort ();
45 return 0;
48 int main (void)
50 check_vect ();
52 return main1 ();
55 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" {xfail { vect_no_align && { ! vect_hw_misalign } } } } } */
56 /* { dg-final { scan-tree-dump-times "dependence distance negative" 1 "vect" { target { ! vect_multiple_sizes } } } } */
57 /* { dg-final { scan-tree-dump "dependence distance negative" "vect" { target vect_multiple_sizes } } } */