mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-15 16:07:49 +00:00
ARM ldm/stm register lists can be out of order.
It's not a good style idea, as the registers will be laid down in memory in numerical order, not the order they're in the list, but it's legal. vldm/vstm are stricter. rdar://11064740 llvm-svn: 152943
This commit is contained in:
parent
9343ed10c6
commit
af19922301
@ -2854,8 +2854,12 @@ parseRegisterList(SmallVectorImpl<MCParsedAsmOperand*> &Operands) {
|
|||||||
if (!RC->contains(Reg))
|
if (!RC->contains(Reg))
|
||||||
return Error(RegLoc, "invalid register in register list");
|
return Error(RegLoc, "invalid register in register list");
|
||||||
// List must be monotonically increasing.
|
// List must be monotonically increasing.
|
||||||
if (getARMRegisterNumbering(Reg) < getARMRegisterNumbering(OldReg))
|
if (getARMRegisterNumbering(Reg) < getARMRegisterNumbering(OldReg)) {
|
||||||
return Error(RegLoc, "register list not in ascending order");
|
if (ARMMCRegisterClasses[ARM::GPRRegClassID].contains(Reg))
|
||||||
|
Warning(RegLoc, "register list not in ascending order");
|
||||||
|
else
|
||||||
|
return Error(RegLoc, "register list not in ascending order");
|
||||||
|
}
|
||||||
if (getARMRegisterNumbering(Reg) == getARMRegisterNumbering(OldReg)) {
|
if (getARMRegisterNumbering(Reg) == getARMRegisterNumbering(OldReg)) {
|
||||||
Warning(RegLoc, "duplicated register (" + RegTok.getString() +
|
Warning(RegLoc, "duplicated register (" + RegTok.getString() +
|
||||||
") in register list");
|
") in register list");
|
||||||
|
@ -216,7 +216,7 @@
|
|||||||
@ Out of order STM registers
|
@ Out of order STM registers
|
||||||
stmda sp!, {r5, r2}
|
stmda sp!, {r5, r2}
|
||||||
|
|
||||||
@ CHECK-ERRORS: error: register list not in ascending order
|
@ CHECK-ERRORS: warning: register list not in ascending order
|
||||||
@ CHECK-ERRORS: stmda sp!, {r5, r2}
|
@ CHECK-ERRORS: stmda sp!, {r5, r2}
|
||||||
@ CHECK-ERRORS: ^
|
@ CHECK-ERRORS: ^
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user