1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-02-01 05:01:59 +01:00

PR20557: Fix the bug that bogus cpu parameter crashes llc on AArch64 backend.

Initial patch by Oleg Ranevskyy.

llvm-svn: 220945
This commit is contained in:
Hao Liu 2014-10-31 02:35:34 +00:00
parent 1369de85df
commit 6cc87eb119
2 changed files with 13 additions and 1 deletions

View File

@ -1200,8 +1200,12 @@ void TargetLoweringBase::computeRegisterProperties() {
TransformToType[i] = MVT::Other;
if (PreferredAction == TypeScalarizeVector)
ValueTypeActions.setTypeAction(VT, TypeScalarizeVector);
else
else if (PreferredAction == TypeSplitVector)
ValueTypeActions.setTypeAction(VT, TypeSplitVector);
else
// Set type action according to the number of elements.
ValueTypeActions.setTypeAction(VT, NElts == 1 ? TypeScalarizeVector
: TypeSplitVector);
} else {
TransformToType[i] = NVT;
ValueTypeActions.setTypeAction(VT, TypeWidenVector);

View File

@ -0,0 +1,8 @@
; RUN: llc -march=aarch64 -mcpu=bogus -o - %s
; Fix the bug in PR20557. Set mcpu to a bogus name, llc will crash in type
; legalization.
define <4 x float> @fneg4(<4 x float> %x) {
%sub = fsub <4 x float> zeroinitializer, %x
ret <4 x float> %sub
}