mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-05 12:31:33 +00:00
Fix a bug in DAGCombine for the optimization of BUILD_VECTOR. We cant generate a shuffle node from two vectors of different types.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@150383 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4a5d7e300e
commit
0877fdf30b
@ -7385,9 +7385,13 @@ SDValue DAGCombiner::visitBUILD_VECTOR(SDNode *N) {
|
||||
// If VecIn2 is unused then change it to undef.
|
||||
VecIn2 = VecIn2.getNode() ? VecIn2 : DAG.getUNDEF(VT);
|
||||
|
||||
// Check that we were able to transform all incoming values to the same type.
|
||||
if (VecIn2.getValueType() != VecIn1.getValueType() ||
|
||||
VecIn1.getValueType() != VT)
|
||||
return SDValue();
|
||||
|
||||
// Only type-legal BUILD_VECTOR nodes are converted to shuffle nodes.
|
||||
if (!isTypeLegal(VT) || !isTypeLegal(VecIn1.getValueType()) ||
|
||||
!isTypeLegal(VecIn2.getValueType()))
|
||||
if (!isTypeLegal(VT))
|
||||
return SDValue();
|
||||
|
||||
// Return the new VECTOR_SHUFFLE node.
|
||||
|
16
test/CodeGen/X86/2012-02-12-dagco.ll
Normal file
16
test/CodeGen/X86/2012-02-12-dagco.ll
Normal file
@ -0,0 +1,16 @@
|
||||
; RUN: llc < %s -mtriple=x86_64-apple-darwin -mcpu=corei7-avx -mattr=+avx
|
||||
target triple = "x86_64-unknown-linux-gnu"
|
||||
; Make sure we are not crashing on this one
|
||||
define void @dagco_crash() {
|
||||
entry:
|
||||
%srcval.i411.i = load <4 x i64>* undef, align 1
|
||||
%0 = extractelement <4 x i64> %srcval.i411.i, i32 3
|
||||
%srcval.i409.i = load <2 x i64>* undef, align 1
|
||||
%1 = extractelement <2 x i64> %srcval.i409.i, i32 0
|
||||
%2 = insertelement <8 x i64> undef, i64 %0, i32 5
|
||||
%3 = insertelement <8 x i64> %2, i64 %1, i32 6
|
||||
%4 = insertelement <8 x i64> %3, i64 undef, i32 7
|
||||
store <8 x i64> %4, <8 x i64> addrspace(1)* undef, align 64
|
||||
unreachable
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user