mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-01 05:01:59 +01:00
[CodeGen] Check FoldConstantArithmetic result before using it.
Fixes PR24602: r245689 introduced an unguarded use of SelectionDAG::FoldConstantArithmetic, which returns 0 when it fails because of opaque (hoisted) constants. llvm-svn: 246217
This commit is contained in:
parent
f08562247d
commit
1b9d52c280
@ -4457,8 +4457,9 @@ SDValue DAGCombiner::visitSHL(SDNode *N) {
|
||||
// fold (shl (mul x, c1), c2) -> (mul x, c1 << c2)
|
||||
if (N1C && N0.getOpcode() == ISD::MUL && N0.getNode()->hasOneUse()) {
|
||||
if (ConstantSDNode *N0C1 = isConstOrConstSplat(N0.getOperand(1))) {
|
||||
SDValue Folded = DAG.FoldConstantArithmetic(ISD::SHL, SDLoc(N1), VT, N0C1, N1C);
|
||||
return DAG.getNode(ISD::MUL, SDLoc(N), VT, N0.getOperand(0), Folded);
|
||||
if (SDValue Folded =
|
||||
DAG.FoldConstantArithmetic(ISD::SHL, SDLoc(N1), VT, N0C1, N1C))
|
||||
return DAG.getNode(ISD::MUL, SDLoc(N), VT, N0.getOperand(0), Folded);
|
||||
}
|
||||
}
|
||||
|
||||
|
17
test/CodeGen/X86/pr24602.ll
Normal file
17
test/CodeGen/X86/pr24602.ll
Normal file
@ -0,0 +1,17 @@
|
||||
; RUN: llc < %s -mtriple=x86_64-unknown-unknown | FileCheck %s
|
||||
|
||||
; PR24602: Make sure we don't barf on non-foldable code (with opaque constants).
|
||||
|
||||
; CHECK-LABEL: pr24602:
|
||||
; CHECK-NEXT: # BB#0
|
||||
; CHECK-NEXT: movabsq $-10000000000, [[CST:%[a-z0-9]+]]
|
||||
; CHECK-NEXT: imulq [[CST]], %rsi
|
||||
; CHECK-NEXT: leaq (%rdi,%rsi,8), %rax
|
||||
; CHECK-NEXT: movq [[CST]], (%rdi,%rsi,8)
|
||||
; CHECK-NEXT: retq
|
||||
define i64* @pr24602(i64* %p, i64 %n) nounwind {
|
||||
%mul = mul nsw i64 %n, -10000000000
|
||||
%add.ptr = getelementptr inbounds i64, i64* %p, i64 %mul
|
||||
store i64 -10000000000, i64* %add.ptr
|
||||
ret i64* %add.ptr
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user