[mips] Honour -mno-odd-spreg for vector insert/extract when MSA is enabled.
authorDaniel Sanders <daniel.sanders@imgtec.com>
Mon, 23 Feb 2015 17:22:16 +0000 (17:22 +0000)
committerDaniel Sanders <daniel.sanders@imgtec.com>
Mon, 23 Feb 2015 17:22:16 +0000 (17:22 +0000)
commitb50b4e2d3654790cfa99cea84369bd9829c58b79
treef41b622161cab5f64d721032ea7d73cbc7d4af83
parent5820b515462fa79b2b3b1af8d1440f6016b1db36
[mips] Honour -mno-odd-spreg for vector insert/extract when MSA is enabled.

Summary:
-mno-odd-spreg prohibits the use of odd-numbered single-precision floating
point registers. However, vector insert/extract was still using them when
manipulating the subregisters of an MSA register. Fixed this by ensuring
that insertion/extraction is only performed on even-numbered vector
registers when -mno-odd-spreg is given.

Reviewers: vmedic, sstankovic

Reviewed By: sstankovic

Subscribers: llvm-commits

Differential Revision: http://reviews.llvm.org/D7672

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@230235 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/Mips/MipsRegisterInfo.td
lib/Target/Mips/MipsSEISelLowering.cpp
test/CodeGen/Mips/no-odd-spreg-msa.ll [new file with mode: 0644]