1 /* { dg-do compile } */
2 /* { dg-options "-O2 -ftree-loop-distribution -fdump-tree-ldist-all" } */
4 void foo (int * __restrict__ ia,
6 int * __restrict__ oxa,
7 int * __restrict__ oxb,
8 int * __restrict__ oya,
9 int * __restrict__ oyb)
15 for (i=0; i < 52; i++)
17 mya[i] = ia[i] * oxa[i] + ib[i] * oxb[i];
18 myb[i] = -ia[i] * oxb[i] + ib[i] * oxa[i];
19 oya[i] = mya[i] >> 10;
20 oyb[i] = myb[i] >> 10;
23 /* This loop was distributed, but it is not anymore due to the cost
24 model changes: the result of a distribution would look like this:
26 | for (i=0; i < 52; i++)
27 | oya[i] = ia[i] * oxa[i] + ib[i] * oxb[i] >> 10;
29 | for (i=0; i < 52; i++)
30 | oyb[i] = -ia[i] * oxb[i] + ib[i] * oxa[i] >> 10;
32 and in this the array IA is read in both tasks. For maximizing
33 the cache reuse, ldist does not distributes this loop anymore.
37 /* { dg-final { scan-tree-dump-times "distributed: split to 2 loops" 0 "ldist" } } */
38 /* { dg-final { cleanup-tree-dump "ldist" } } */