summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/strcmpopt_7.c
blob: 5e713170e6fc425a8a636394699c96443cf5eebf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/* PR tree-optimization/92501 - strncmp with constant unterminated arrays
   not folded
   { dg-do compile }
   { dg-options "-O1 -Wall -fdump-tree-forwprop1" } */

/* Unterminated arrays of the size encoded in name.  */
const char a1[] = { '1' };
const char a12[] = { '1', '2' };
const char a112[] = { '1', '1', '2' };
const char a123[] = { '1', '2', '3' };

/* Nul-terminated strings of the length encoded in name.  */
const char s[] = "";
const char s1[] = "1";
const char s12[] = "12";
const char s112[] = "112";
const char s123[] = "123";

extern void failure_on_line (int);

/* Verify that the test in 'if (EQL strncmp (S, T, N))' is folded.  */
#define T(eql, s, t, n) do {			\
    if (!(eql __builtin_strncmp (s, t, n)))	\
      failure_on_line (__LINE__);		\
  } while (0)


void test (void)
{
  /* Mixed array and string.  */
  T (0 ==, a1, "", 0);
  T (0 ==, a1, s, 0);
  T (0 !=, a1, "", 1);
  T (0 !=, a1, s, 1);

  /* The following two are safe to fold because while strncmp compares
     at most N bytes it doesn't compare any bytes past the first nul.  */
  T (0 !=, a1, "", 9);
  T (0 !=, a1, s, 9);

  T (0 ==, a1, "1", 0);
  T (0 ==, a1, s1, 0);
  T (0 ==, a1, "1", 1);
  T (0 ==, a1, s1, 1);
  T (0 ==, a1, "12", 1);
  T (0 ==, a1, s12, 1);

     /* As above, the following three are also safe to fold.  */
  T (0 !=, a1, s12 + 1, 1);
  T (0 !=, a1, s12 + 1, 2);
  T (0 !=, a1, s12 + 1, 9);

  T (0 ==, a12, s, 0);
  T (0 ==, a12, "", 0);
  T (0 ==, a12, s1, 0);
  T (0 ==, a12, "1", 0);
  T (0 ==, a12, s1, 1);
  T (0 ==, a12, "1", 1);
  T (0 !=, a12, s1, 2);
  T (0 !=, a12, "1", 2);
  T (0 ==, a12, s12, 0);
  T (0 ==, a12, "12", 0);
  T (0 ==, a12, s12, 1);
  T (0 ==, a12, "12", 1);
  T (0 ==, a12, s12, 2);
  T (0 ==, a12, "12", 2);
  T (0 ==, a12, s123, 2);
  T (0 ==, a12, "123", 2);

  T (0 ==, a12 + 0, s123 + 1, 0);
  T (0 !=, a12 + 0, s123 + 1, 1);
  T (0 !=, a12 + 0, s123 + 1, 2);
  T (0 ==, a12 + 1, s123 + 0, 0);
  T (0 !=, a12 + 1, s123 + 0, 1);
  T (0 !=, a12 + 1, s123 + 0, 2);
  T (0 ==, a12 + 1, s123 + 1, 1);
  T (0 !=, a12 + 1, s123 + 2, 1);
  T (0 !=, a12 + 1, s123 + 3, 1);

  T (0 ==, a12 + 1, "123" + 1, 1);
  T (0 !=, a12 + 1, "123" + 2, 1);
  T (0 !=, a12 + 1, "123" + 3, 1);
  T (0 !=, a12 + 1, "123" + 3, 9);

  /* Both arguments arrays.  */
  T (0 ==, a112 + 0, a1, 1);
  T (0 ==, a112 + 1, a1, 1);
  T (0 !=, a112 + 2, a1, 1);

  T (0 ==, a1, a112 + 0, 1);
  T (0 ==, a1, a112 + 1, 1);
  T (0 !=, a1, a112 + 2, 1);

  T (0 ==, a112 + 0, a12, 0);
  T (0 ==, a112 + 0, a12, 1);
  T (0 !=, a112 + 0, a12, 2);

  T (0 ==, a112 + 1, a12, 2);
  T (0 !=, a112 + 1, a12 + 1, 1);
  T (0 ==, a112 + 2, a12 + 1, 1);

  /* Mixed array and string.  */
  T (0 ==, s112 + 0, a12, 0);
  T (0 ==, s112 + 0, a12, 1);
  T (0 !=, s112 + 0, a12, 2);

  T (0 ==, s112 + 1, a12, 0);
  T (0 ==, s112 + 1, a12, 1);
  T (0 ==, s112 + 1, a12, 2);
  T (0 !=, s112 + 2, a12, 2);

  T (0 ==, a112 + 0, s1, 1);
  T (0 ==, a112 + 1, s1, 1);
  T (0 !=, a112 + 2, s1, 1);
}

/* { dg-final { scan-tree-dump-not "strcmp" "forwprop1" } }
   { dg-final { scan-tree-dump-not "strncmp" "forwprop1" } }
   { dg-final { scan-tree-dump-not "failure_on_line_" "forwprop1" } } */