annotate gcc/testsuite/gcc.dg/strlenopt-18g.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* This test needs runtime that provides stpcpy function. */
kono
parents:
diff changeset
2 /* { dg-do run { target *-*-linux* *-*-gnu* } } */
kono
parents:
diff changeset
3 /* { dg-options "-O2 -fdump-tree-strlen" } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #define USE_GNU
kono
parents:
diff changeset
6 #include "strlenopt.h"
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 __attribute__((noinline, noclone)) char *
kono
parents:
diff changeset
9 fn1 (int x, int y, int z)
kono
parents:
diff changeset
10 {
kono
parents:
diff changeset
11 static char buf[40];
kono
parents:
diff changeset
12 const char *p;
kono
parents:
diff changeset
13 switch (x)
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 case 0:
kono
parents:
diff changeset
16 p = "abcd";
kono
parents:
diff changeset
17 break;
kono
parents:
diff changeset
18 case 1:
kono
parents:
diff changeset
19 p = "efgh";
kono
parents:
diff changeset
20 break;
kono
parents:
diff changeset
21 case 2:
kono
parents:
diff changeset
22 p = "ijkl";
kono
parents:
diff changeset
23 break;
kono
parents:
diff changeset
24 default:
kono
parents:
diff changeset
25 p = "mnopq";
kono
parents:
diff changeset
26 break;
kono
parents:
diff changeset
27 }
kono
parents:
diff changeset
28 if (y)
kono
parents:
diff changeset
29 {
kono
parents:
diff changeset
30 strcpy (buf, p);
kono
parents:
diff changeset
31 if (z)
kono
parents:
diff changeset
32 strcat (buf, "ABCDEFG");
kono
parents:
diff changeset
33 else
kono
parents:
diff changeset
34 strcat (buf, "HIJKLMN");
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36 else
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 strcpy (buf, p + 1);
kono
parents:
diff changeset
39 if (z)
kono
parents:
diff changeset
40 strcat (buf, "OPQ");
kono
parents:
diff changeset
41 else
kono
parents:
diff changeset
42 strcat (buf, "RST");
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44 return buf;
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 int
kono
parents:
diff changeset
48 main ()
kono
parents:
diff changeset
49 {
kono
parents:
diff changeset
50 int i;
kono
parents:
diff changeset
51 for (i = 0; i < 5; i++)
kono
parents:
diff changeset
52 {
kono
parents:
diff changeset
53 const char *p = "abcdefghijklmnopq" + (i < 3 ? i : 3) * 4;
kono
parents:
diff changeset
54 const char *q;
kono
parents:
diff changeset
55 int j = i >= 3;
kono
parents:
diff changeset
56 fn1 (i ? 0 : 1, 1, 1);
kono
parents:
diff changeset
57 q = fn1 (i, 0, 0);
kono
parents:
diff changeset
58 if (memcmp (q, p + 1, 3 + j) != 0 || memcmp (q + 3 + j, "RST", 4) != 0)
kono
parents:
diff changeset
59 abort ();
kono
parents:
diff changeset
60 fn1 (i ? 0 : 1, 0, 1);
kono
parents:
diff changeset
61 q = fn1 (i, 1, 0);
kono
parents:
diff changeset
62 if (memcmp (q, p, 4 + j) != 0 || memcmp (q + 4 + j, "HIJKLMN", 8) != 0)
kono
parents:
diff changeset
63 abort ();
kono
parents:
diff changeset
64 fn1 (i ? 0 : 1, 1, 0);
kono
parents:
diff changeset
65 q = fn1 (i, 0, 1);
kono
parents:
diff changeset
66 if (memcmp (q, p + 1, 3 + j) != 0 || memcmp (q + 3 + j, "OPQ", 4) != 0)
kono
parents:
diff changeset
67 abort ();
kono
parents:
diff changeset
68 fn1 (i ? 0 : 1, 0, 0);
kono
parents:
diff changeset
69 q = fn1 (i, 1, 1);
kono
parents:
diff changeset
70 if (memcmp (q, p, 4 + j) != 0 || memcmp (q + 4 + j, "ABCDEFG", 8) != 0)
kono
parents:
diff changeset
71 abort ();
kono
parents:
diff changeset
72 }
kono
parents:
diff changeset
73 return 0;
kono
parents:
diff changeset
74 }
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 /* { dg-final { scan-tree-dump-times "strlen \\(" 0 "strlen" } } */
kono
parents:
diff changeset
77 /* { dg-final { scan-tree-dump-times "memcpy \\(" 4 "strlen" } } */
kono
parents:
diff changeset
78 /* { dg-final { scan-tree-dump-times "strcpy \\(" 0 "strlen" } } */
kono
parents:
diff changeset
79 /* { dg-final { scan-tree-dump-times "strcat \\(" 0 "strlen" } } */
kono
parents:
diff changeset
80 /* { dg-final { scan-tree-dump-times "strchr \\(" 0 "strlen" } } */
kono
parents:
diff changeset
81 /* { dg-final { scan-tree-dump-times "stpcpy \\(" 2 "strlen" } } */