xref: /llvm-project/llvm/test/Transforms/InstCombine/memchr-10.ll (revision 2caaec65c04ea7d0e9568b7895b7a46d6100cb75)
1e263a767SMartin Sebor; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2e263a767SMartin Sebor; RUN: opt < %s -passes=instcombine -S | FileCheck %s
3e263a767SMartin Sebor;
4e263a767SMartin Sebor; Verify that the result of memchr calls with past-the-end pointers used
5e263a767SMartin Sebor; in equality expressions don't cause trouble and either are folded when
6e263a767SMartin Sebor; they might be valid or not when they're provably undefined.
7e263a767SMartin Sebor
84ab40ecaSBjorn Petterssondeclare ptr @memchr(ptr, i32, i64)
9e263a767SMartin Sebor
10e263a767SMartin Sebor
11e263a767SMartin Sebor@a5 = constant [5 x i8] c"12345"
12e263a767SMartin Sebor
13e263a767SMartin Sebor
14e263a767SMartin Sebor; Fold memchr(a5 + 5, c, 1) == a5 + 5 to an arbitrary constrant.
15e263a767SMartin Sebor; The call is transformed to a5[5] == c by the memchr simplifier, with
16e263a767SMartin Sebor; a5[5] being indeterminate.  The equality then is the folded with
17e263a767SMartin Sebor; an undefined/arbitrary result.
18e263a767SMartin Sebor
19e263a767SMartin Sebordefine i1 @call_memchr_ap5_c_1_eq_a(i32 %c, i64 %n) {
20e263a767SMartin Sebor; CHECK-LABEL: @call_memchr_ap5_c_1_eq_a(
21*2caaec65SNikita Popov; CHECK-NEXT:    ret i1 poison
22e263a767SMartin Sebor;
234ab40ecaSBjorn Pettersson  %pap5 = getelementptr [5 x i8], ptr @a5, i32 0, i32 5
244ab40ecaSBjorn Pettersson  %qap5 = getelementptr [5 x i8], ptr @a5, i32 1, i32 0
254ab40ecaSBjorn Pettersson  %q = call ptr @memchr(ptr %pap5, i32 %c, i64 1)
264ab40ecaSBjorn Pettersson  %cmp = icmp eq ptr %q, %qap5
27e263a767SMartin Sebor  ret i1 %cmp
28e263a767SMartin Sebor}
29e263a767SMartin Sebor
30e263a767SMartin Sebor
31e263a767SMartin Sebor; Fold memchr(a5 + 5, c, 5) == a5 + 5 to an arbitrary constant.
32e263a767SMartin Sebor
33e263a767SMartin Sebordefine i1 @call_memchr_ap5_c_5_eq_a(i32 %c, i64 %n) {
34e263a767SMartin Sebor; CHECK-LABEL: @call_memchr_ap5_c_5_eq_a(
35*2caaec65SNikita Popov; CHECK-NEXT:    ret i1 poison
36e263a767SMartin Sebor;
374ab40ecaSBjorn Pettersson  %pap5 = getelementptr [5 x i8], ptr @a5, i32 0, i32 5
384ab40ecaSBjorn Pettersson  %qap5 = getelementptr [5 x i8], ptr @a5, i32 1, i32 0
394ab40ecaSBjorn Pettersson  %q = call ptr @memchr(ptr %pap5, i32 %c, i64 5)
404ab40ecaSBjorn Pettersson  %cmp = icmp eq ptr %q, %qap5
41e263a767SMartin Sebor  ret i1 %cmp
42e263a767SMartin Sebor}
43e263a767SMartin Sebor
44e263a767SMartin Sebor
45e263a767SMartin Sebor; Fold memchr(a5 + 5, c, n) == a5 to false.
46e263a767SMartin Sebor
47e263a767SMartin Sebordefine i1 @fold_memchr_ap5_c_n_eq_a(i32 %c, i64 %n) {
48e263a767SMartin Sebor; CHECK-LABEL: @fold_memchr_ap5_c_n_eq_a(
49e263a767SMartin Sebor; CHECK-NEXT:    ret i1 false
50e263a767SMartin Sebor;
514ab40ecaSBjorn Pettersson  %pap5 = getelementptr [5 x i8], ptr @a5, i32 0, i32 5
524ab40ecaSBjorn Pettersson  %q = call ptr @memchr(ptr %pap5, i32 %c, i64 %n)
534ab40ecaSBjorn Pettersson  %cmp = icmp eq ptr %q, @a5
54e263a767SMartin Sebor  ret i1 %cmp
55e263a767SMartin Sebor}
56e263a767SMartin Sebor
57e263a767SMartin Sebor
58e263a767SMartin Sebor; Fold memchr(a5 + 5, c, n) == null to true on the basis that n must
59e263a767SMartin Sebor; be zero in order for the call to be valid.
60e263a767SMartin Sebor
61e263a767SMartin Sebordefine i1 @fold_memchr_ap5_c_n_eqz(i32 %c, i64 %n) {
62e263a767SMartin Sebor; CHECK-LABEL: @fold_memchr_ap5_c_n_eqz(
63e263a767SMartin Sebor; CHECK-NEXT:    ret i1 true
64e263a767SMartin Sebor;
654ab40ecaSBjorn Pettersson  %p = getelementptr [5 x i8], ptr @a5, i32 0, i32 5
664ab40ecaSBjorn Pettersson  %q = call ptr @memchr(ptr %p, i32 %c, i64 %n)
674ab40ecaSBjorn Pettersson  %cmp = icmp eq ptr %q, null
68e263a767SMartin Sebor  ret i1 %cmp
69e263a767SMartin Sebor}
70e263a767SMartin Sebor
71e263a767SMartin Sebor
72e263a767SMartin Sebor; Fold memchr(a5 + 5, '\0', n) == null to true on the basis that n must
73e263a767SMartin Sebor; be zero in order for the call to be valid.
74e263a767SMartin Sebor
75e263a767SMartin Sebordefine i1 @fold_memchr_a_nul_n_eqz(i64 %n) {
76e263a767SMartin Sebor; CHECK-LABEL: @fold_memchr_a_nul_n_eqz(
77e263a767SMartin Sebor; CHECK-NEXT:    ret i1 true
78e263a767SMartin Sebor;
794ab40ecaSBjorn Pettersson  %p = getelementptr [5 x i8], ptr @a5, i32 0, i32 5
804ab40ecaSBjorn Pettersson  %q = call ptr @memchr(ptr %p, i32 0, i64 %n)
814ab40ecaSBjorn Pettersson  %cmp = icmp eq ptr %q, null
82e263a767SMartin Sebor  ret i1 %cmp
83e263a767SMartin Sebor}
84