annotate gcc/testsuite/gcc.target/powerpc/doloop-2.c @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
152
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
1 /* { dg-do compile } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
2 /* { dg-options "-O2 -fno-unroll-loops" } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
3
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
4 unsigned int
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
5 foo1 (unsigned int l, int *a)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
6 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
7 unsigned int i;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
8 for(i = 0;i < l; i++)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
9 a[i] = i;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
10 return l;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
11 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
12
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
13 int
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
14 foo2 (int l, int *a)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
15 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
16 int i;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
17 for(i = 0;i < l; i++)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
18 a[i] = i;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
19 return l;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
20 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
21
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
22 /* The place where we were getting an extra -1 is when converting from 32bits
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 to 64bits as the ctr register is used as 64bits on powerpc64. We should be
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24 able to do this loop without "add -1/zero_ext/add 1" to the l to get the
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 number of iterations of this loop still doing a do-loop. */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 /* { dg-final { scan-assembler-not {(?n)\maddi .*,.*,-1$} } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
28 /* { dg-final { scan-assembler-times "bdnz" 2 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
29 /* { dg-final { scan-assembler-times "mtctr" 2 } } */