AArch64: use RegisterOperand for NEON registers.
authorTim Northover <tnorthover@apple.com>
Fri, 13 Sep 2013 07:26:52 +0000 (07:26 +0000)
committerTim Northover <tnorthover@apple.com>
Fri, 13 Sep 2013 07:26:52 +0000 (07:26 +0000)
commit630c5e06d633fad142af4b145ee684e90754700e
treec3cbf46f05c9144cd434f687ca36d9247529d7b7
parentdc6fc4fa1f88e4accf1abe6db67399496bfe18b2
AArch64: use RegisterOperand for NEON registers.

Previously we modelled VPR128 and VPR64 as essentially identical
register-classes containing V0-V31 (which had Q0-Q31 as "sub_alias"
sub-registers). This model is starting to cause significant problems
for code generation, particularly writing EXTRACT/INSERT_SUBREG
patterns for converting between the two.

The change here switches to classifying VPR64 & VPR128 as
RegisterOperands, which are essentially aliases for RegisterClasses
with different parsing and printing behaviour. This fits almost
exactly with their real status (VPR128 == FPR128 printed strangely,
VPR64 == FPR64 printed strangely).

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@190665 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/AArch64/AArch64AsmPrinter.cpp
lib/Target/AArch64/AArch64ISelLowering.cpp
lib/Target/AArch64/AArch64InstrInfo.td
lib/Target/AArch64/AArch64InstrNEON.td
lib/Target/AArch64/AArch64RegisterInfo.td
lib/Target/AArch64/AsmParser/AArch64AsmParser.cpp
lib/Target/AArch64/Disassembler/AArch64Disassembler.cpp
lib/Target/AArch64/InstPrinter/AArch64InstPrinter.cpp
lib/Target/AArch64/InstPrinter/AArch64InstPrinter.h
test/MC/AArch64/neon-mov.s
test/MC/Disassembler/AArch64/neon-instructions.txt