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 memrchr 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 @memrchr(ptr, i32, i64) 9e263a767SMartin Sebor 10e263a767SMartin Sebor 11e263a767SMartin Sebor@a5 = constant [5 x i8] c"12345" 12e263a767SMartin Sebor 13e263a767SMartin Sebor 14e263a767SMartin Sebor; Fold memrchr(a5 + 5, c, 1) == a5 + 5 to an arbitrary constant. 15e263a767SMartin Sebor; The call is transformed to a5[5] == c by the memrchr 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_memrchr_ap5_c_1_eq_a(i32 %c, i64 %n) { 20e263a767SMartin Sebor; CHECK-LABEL: @call_memrchr_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 @memrchr(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 memrchr(a5 + 5, c, 5) == a5 + 5 to an arbitrary constant. 32e263a767SMartin Sebor 33e263a767SMartin Sebordefine i1 @call_memrchr_ap5_c_5_eq_a(i32 %c, i64 %n) { 34e263a767SMartin Sebor; CHECK-LABEL: @call_memrchr_ap5_c_5_eq_a( 35*2caaec65SNikita Popov; CHECK-NEXT: ret i1 false 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 @memrchr(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 memrchr(a5 + 5, c, n) == a5 to false. 46e263a767SMartin Sebor 47e263a767SMartin Sebordefine i1 @fold_memrchr_ap5_c_n_eq_a(i32 %c, i64 %n) { 48e263a767SMartin Sebor; CHECK-LABEL: @fold_memrchr_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 @memrchr(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 memrchr(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_memrchr_ap5_c_n_eqz(i32 %c, i64 %n) { 62e263a767SMartin Sebor; CHECK-LABEL: @fold_memrchr_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 @memrchr(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 memrchr(a5 + 5, '\0', n) == null to true again on the basis that 73e263a767SMartin Sebor; n must be zero in order for the call to be valid. 74e263a767SMartin Sebor 75e263a767SMartin Sebordefine i1 @fold_memrchr_a_nul_n_eqz(i64 %n) { 76e263a767SMartin Sebor; CHECK-LABEL: @fold_memrchr_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 @memrchr(ptr %p, i32 0, i64 %n) 814ab40ecaSBjorn Pettersson %cmp = icmp eq ptr %q, null 82e263a767SMartin Sebor ret i1 %cmp 83e263a767SMartin Sebor} 84