mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 17:39:16 +00:00
When transforming a vector_shuffle to a load, the base address must not be an undef.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@50940 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
49ff661410
commit
50d9e7289b
@ -6283,6 +6283,8 @@ static bool EltsFromConsecutiveLoads(SDNode *N, SDOperand PermMask,
|
||||
return false;
|
||||
if (!Base) {
|
||||
Base = Elt.Val;
|
||||
if (Base->getOpcode() == ISD::UNDEF)
|
||||
return false;
|
||||
continue;
|
||||
}
|
||||
if (Elt.getOpcode() == ISD::UNDEF)
|
||||
|
10
test/CodeGen/X86/2008-05-09-ShuffleLoweringBug.ll
Normal file
10
test/CodeGen/X86/2008-05-09-ShuffleLoweringBug.ll
Normal file
@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2
|
||||
|
||||
define fastcc void @glgVectorFloatConversion() nounwind {
|
||||
%tmp12745 = load <4 x float>* null, align 16 ; <<4 x float>> [#uses=1]
|
||||
%tmp12773 = insertelement <4 x float> %tmp12745, float 1.000000e+00, i32 1 ; <<4 x float>> [#uses=1]
|
||||
%tmp12774 = insertelement <4 x float> %tmp12773, float 0.000000e+00, i32 2 ; <<4 x float>> [#uses=1]
|
||||
%tmp12775 = insertelement <4 x float> %tmp12774, float 1.000000e+00, i32 3 ; <<4 x float>> [#uses=1]
|
||||
store <4 x float> %tmp12775, <4 x float>* null, align 16
|
||||
unreachable
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user