mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-15 07:59:57 +00:00
[InstCombine] fix propagation of fast-math-flags
Noticed while working on D4583: http://reviews.llvm.org/D4583 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@253997 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
22b828d817
commit
4da18f10ae
@ -1245,16 +1245,11 @@ Value *InstCombiner::Descale(Value *Val, APInt Scale, bool &NoSignedWrap) {
|
||||
/// specified one but with other operands.
|
||||
static Value *CreateBinOpAsGiven(BinaryOperator &Inst, Value *LHS, Value *RHS,
|
||||
InstCombiner::BuilderTy *B) {
|
||||
Value *BORes = B->CreateBinOp(Inst.getOpcode(), LHS, RHS);
|
||||
if (BinaryOperator *NewBO = dyn_cast<BinaryOperator>(BORes)) {
|
||||
if (isa<OverflowingBinaryOperator>(NewBO)) {
|
||||
NewBO->setHasNoSignedWrap(Inst.hasNoSignedWrap());
|
||||
NewBO->setHasNoUnsignedWrap(Inst.hasNoUnsignedWrap());
|
||||
}
|
||||
if (isa<PossiblyExactOperator>(NewBO))
|
||||
NewBO->setIsExact(Inst.isExact());
|
||||
}
|
||||
return BORes;
|
||||
Value *BO = B->CreateBinOp(Inst.getOpcode(), LHS, RHS);
|
||||
// If LHS and RHS are constant, BO won't be a binary operator.
|
||||
if (BinaryOperator *NewBO = dyn_cast<BinaryOperator>(BO))
|
||||
NewBO->copyIRFlags(&Inst);
|
||||
return BO;
|
||||
}
|
||||
|
||||
/// \brief Makes transformation of binary operation specific for vector types.
|
||||
|
@ -310,16 +310,16 @@ define <4 x i32> @shuffle_17addnuw(<4 x i32> %v1, <4 x i32> %v2) nounwind uwtabl
|
||||
ret <4 x i32> %r
|
||||
}
|
||||
|
||||
define <4 x float> @shuffle_17fsub(<4 x float> %v1, <4 x float> %v2) nounwind uwtable {
|
||||
; CHECK-LABEL: @shuffle_17fsub(
|
||||
; CHECK-NOT: shufflevector
|
||||
; CHECK: fsub <4 x float> %v1, %v2
|
||||
; CHECK: shufflevector
|
||||
define <4 x float> @shuffle_17fsub_fast(<4 x float> %v1, <4 x float> %v2) nounwind uwtable {
|
||||
; CHECK-LABEL: @shuffle_17fsub_fast(
|
||||
; CHECK-NEXT: [[VAR1:%[a-zA-Z0-9.]+]] = fsub fast <4 x float> %v1, %v2
|
||||
; CHECK-NEXT: shufflevector <4 x float> [[VAR1]], <4 x float> undef, <4 x i32> <i32 1, i32 2, i32 3, i32 0>
|
||||
; CHECK-NEXT: ret <4 x float>
|
||||
%t1 = shufflevector <4 x float> %v1, <4 x float> zeroinitializer,
|
||||
<4 x i32> <i32 1, i32 2, i32 3, i32 0>
|
||||
%t2 = shufflevector <4 x float> %v2, <4 x float> zeroinitializer,
|
||||
<4 x i32> <i32 1, i32 2, i32 3, i32 0>
|
||||
%r = fsub <4 x float> %t1, %t2
|
||||
%r = fsub fast <4 x float> %t1, %t2
|
||||
ret <4 x float> %r
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user