xref: /llvm-project/llvm/test/Transforms/InstCombine/pr38915.ll (revision 2caaec65c04ea7d0e9568b7895b7a46d6100cb75)
1; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2; RUN: opt < %s -passes=instcombine -S | FileCheck %s
3
4define i32 @PR38915(i32 %x, i32 %y, i32 %z) {
5; CHECK-LABEL: @PR38915(
6; CHECK-NEXT:    [[TMP1:%.*]] = add i32 [[X:%.*]], -1
7; CHECK-NEXT:    [[TMP2:%.*]] = add i32 [[Y:%.*]], -1
8; CHECK-NEXT:    [[M1N:%.*]] = call i32 @llvm.smin.i32(i32 [[TMP1]], i32 [[TMP2]])
9; CHECK-NEXT:    [[M2:%.*]] = call i32 @llvm.smax.i32(i32 [[M1N]], i32 [[Z:%.*]])
10; CHECK-NEXT:    [[M2N:%.*]] = xor i32 [[M2]], -1
11; CHECK-NEXT:    ret i32 [[M2N]]
12;
13  %xn = sub i32 0, %x
14  %yn = sub i32 0, %y
15  %c1 = icmp sgt i32 %xn, %yn
16  %m1 = select i1 %c1, i32 %xn, i32 %yn
17  %m1n = xor i32 %m1, -1
18  %c2 = icmp sgt i32 %m1n, %z
19  %m2 = select i1 %c2, i32 %m1n, i32 %z
20  %m2n = xor i32 %m2, -1
21  ret i32 %m2n
22}
23