2020-01-04 21:43:34 +08:00
|
|
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
|
|
|
; RUN: opt -S < %s -instcombine | FileCheck %s
|
|
|
|
|
|
|
|
; Fold
|
|
|
|
; sub %Op0, (select %Cond, %TrueVal, %FalseVal)
|
|
|
|
; to
|
|
|
|
; select %Cond, (sub %Op0, %TrueVal), (sub %Op0, %FalseVal)
|
|
|
|
|
|
|
|
; https://bugs.llvm.org/show_bug.cgi?id=44426
|
|
|
|
|
|
|
|
; Base tests
|
|
|
|
|
|
|
|
define i8 @t0_sub_from_trueval(i1 %c, i8 %Op0, i8 %FalseVal) {
|
|
|
|
; CHECK-LABEL: @t0_sub_from_trueval(
|
[InstCombine] Sink sub into hands of select if one hand becomes zero. Part 2 (PR44426)
This decreases use count of %Op0, makes one hand of select to be 0,
and possibly exposes further folding potential.
Name: sub %Op0, (select %Cond, %Op0, %FalseVal) -> select %Cond, 0, (sub %Op0, %FalseVal)
%Op0 = %TrueVal
%o = select i1 %Cond, i8 %Op0, i8 %FalseVal
%r = sub i8 %Op0, %o
=>
%n = sub i8 %Op0, %FalseVal
%r = select i1 %Cond, i8 0, i8 %n
Name: sub %Op0, (select %Cond, %TrueVal, %Op0) -> select %Cond, (sub %Op0, %TrueVal), 0
%Op0 = %FalseVal
%o = select i1 %Cond, i8 %TrueVal, i8 %Op0
%r = sub i8 %Op0, %o
=>
%n = sub i8 %Op0, %TrueVal
%r = select i1 %Cond, i8 %n, i8 0
https://rise4fun.com/Alive/aHRt
https://bugs.llvm.org/show_bug.cgi?id=44426
2020-01-04 21:50:53 +08:00
|
|
|
; CHECK-NEXT: [[TMP1:%.*]] = sub i8 [[OP0:%.*]], [[FALSEVAL:%.*]]
|
|
|
|
; CHECK-NEXT: [[R:%.*]] = select i1 [[C:%.*]], i8 0, i8 [[TMP1]], !prof !0
|
2020-01-04 21:43:34 +08:00
|
|
|
; CHECK-NEXT: ret i8 [[R]]
|
|
|
|
;
|
|
|
|
%o = select i1 %c, i8 %Op0, i8 %FalseVal, !prof !0 ; while there, ensure preservation of prof md
|
|
|
|
%r = sub i8 %Op0, %o
|
|
|
|
ret i8 %r
|
|
|
|
}
|
|
|
|
define i8 @t1_sub_from_falseval(i1 %c, i8 %TrueVal, i8 %Op0) {
|
|
|
|
; CHECK-LABEL: @t1_sub_from_falseval(
|
[InstCombine] Sink sub into hands of select if one hand becomes zero. Part 2 (PR44426)
This decreases use count of %Op0, makes one hand of select to be 0,
and possibly exposes further folding potential.
Name: sub %Op0, (select %Cond, %Op0, %FalseVal) -> select %Cond, 0, (sub %Op0, %FalseVal)
%Op0 = %TrueVal
%o = select i1 %Cond, i8 %Op0, i8 %FalseVal
%r = sub i8 %Op0, %o
=>
%n = sub i8 %Op0, %FalseVal
%r = select i1 %Cond, i8 0, i8 %n
Name: sub %Op0, (select %Cond, %TrueVal, %Op0) -> select %Cond, (sub %Op0, %TrueVal), 0
%Op0 = %FalseVal
%o = select i1 %Cond, i8 %TrueVal, i8 %Op0
%r = sub i8 %Op0, %o
=>
%n = sub i8 %Op0, %TrueVal
%r = select i1 %Cond, i8 %n, i8 0
https://rise4fun.com/Alive/aHRt
https://bugs.llvm.org/show_bug.cgi?id=44426
2020-01-04 21:50:53 +08:00
|
|
|
; CHECK-NEXT: [[TMP1:%.*]] = sub i8 [[OP0:%.*]], [[TRUEVAL:%.*]]
|
|
|
|
; CHECK-NEXT: [[R:%.*]] = select i1 [[C:%.*]], i8 [[TMP1]], i8 0, !prof !0
|
2020-01-04 21:43:34 +08:00
|
|
|
; CHECK-NEXT: ret i8 [[R]]
|
|
|
|
;
|
|
|
|
%o = select i1 %c, i8 %TrueVal, i8 %Op0, !prof !0 ; while there, ensure preservation of prof md
|
|
|
|
%r = sub i8 %Op0, %o
|
|
|
|
ret i8 %r
|
|
|
|
}
|
|
|
|
|
|
|
|
; Vectors
|
|
|
|
|
|
|
|
define <2 x i8> @t2_vec(i1 %c, <2 x i8> %Op0, <2 x i8> %FalseVal) {
|
|
|
|
; CHECK-LABEL: @t2_vec(
|
[InstCombine] Sink sub into hands of select if one hand becomes zero. Part 2 (PR44426)
This decreases use count of %Op0, makes one hand of select to be 0,
and possibly exposes further folding potential.
Name: sub %Op0, (select %Cond, %Op0, %FalseVal) -> select %Cond, 0, (sub %Op0, %FalseVal)
%Op0 = %TrueVal
%o = select i1 %Cond, i8 %Op0, i8 %FalseVal
%r = sub i8 %Op0, %o
=>
%n = sub i8 %Op0, %FalseVal
%r = select i1 %Cond, i8 0, i8 %n
Name: sub %Op0, (select %Cond, %TrueVal, %Op0) -> select %Cond, (sub %Op0, %TrueVal), 0
%Op0 = %FalseVal
%o = select i1 %Cond, i8 %TrueVal, i8 %Op0
%r = sub i8 %Op0, %o
=>
%n = sub i8 %Op0, %TrueVal
%r = select i1 %Cond, i8 %n, i8 0
https://rise4fun.com/Alive/aHRt
https://bugs.llvm.org/show_bug.cgi?id=44426
2020-01-04 21:50:53 +08:00
|
|
|
; CHECK-NEXT: [[TMP1:%.*]] = sub <2 x i8> [[OP0:%.*]], [[FALSEVAL:%.*]]
|
|
|
|
; CHECK-NEXT: [[R:%.*]] = select i1 [[C:%.*]], <2 x i8> zeroinitializer, <2 x i8> [[TMP1]]
|
2020-01-04 21:43:34 +08:00
|
|
|
; CHECK-NEXT: ret <2 x i8> [[R]]
|
|
|
|
;
|
|
|
|
%o = select i1 %c, <2 x i8> %Op0, <2 x i8> %FalseVal
|
|
|
|
%r = sub <2 x i8> %Op0, %o
|
|
|
|
ret <2 x i8> %r
|
|
|
|
}
|
|
|
|
|
|
|
|
; Extra use
|
|
|
|
|
|
|
|
declare void @use8(i8)
|
|
|
|
|
|
|
|
define i8 @n3_extrause(i1 %c, i8 %Op0, i8 %FalseVal) {
|
|
|
|
; CHECK-LABEL: @n3_extrause(
|
|
|
|
; CHECK-NEXT: [[O:%.*]] = select i1 [[C:%.*]], i8 [[OP0:%.*]], i8 [[FALSEVAL:%.*]]
|
|
|
|
; CHECK-NEXT: call void @use8(i8 [[O]])
|
|
|
|
; CHECK-NEXT: [[R:%.*]] = sub i8 [[OP0]], [[O]]
|
|
|
|
; CHECK-NEXT: ret i8 [[R]]
|
|
|
|
;
|
|
|
|
%o = select i1 %c, i8 %Op0, i8 %FalseVal
|
|
|
|
call void @use8(i8 %o)
|
|
|
|
%r = sub i8 %Op0, %o
|
|
|
|
ret i8 %r
|
|
|
|
}
|
|
|
|
|
|
|
|
; Negative tests
|
|
|
|
|
|
|
|
define i8 @n4_wrong_hands(i1 %c, i8 %TrueVal, i8 %FalseVal, i8 %Op0) {
|
|
|
|
; CHECK-LABEL: @n4_wrong_hands(
|
|
|
|
; CHECK-NEXT: [[O:%.*]] = select i1 [[C:%.*]], i8 [[TRUEVAL:%.*]], i8 [[FALSEVAL:%.*]]
|
|
|
|
; CHECK-NEXT: [[R:%.*]] = sub i8 [[OP0:%.*]], [[O]]
|
|
|
|
; CHECK-NEXT: ret i8 [[R]]
|
|
|
|
;
|
|
|
|
%o = select i1 %c, i8 %TrueVal, i8 %FalseVal ; none of the hands is %Op0
|
|
|
|
%r = sub i8 %Op0, %o
|
|
|
|
ret i8 %r
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK: !0 = !{!"branch_weights", i32 0, i32 100}
|
|
|
|
!0 = !{!"branch_weights", i32 0, i32 100}
|