mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
[ARM] Make the assembler reject unpredictable pre/post-indexed ARM STRH instructions.
The ARM ARM prohibits STRH instructions with writeback into the source register. With this commit this constraint is now enforced and we stop assembling STRH instructions with unpredictable behavior. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@213850 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
25f4fcd8e0
commit
d51310e486
@ -5732,6 +5732,8 @@ bool ARMAsmParser::validateInstruction(MCInst &Inst,
|
||||
case ARM::STR_PRE_REG:
|
||||
case ARM::STR_POST_IMM:
|
||||
case ARM::STR_POST_REG:
|
||||
case ARM::STRH_PRE:
|
||||
case ARM::STRH_POST:
|
||||
case ARM::STRB_PRE_IMM:
|
||||
case ARM::STRB_PRE_REG:
|
||||
case ARM::STRB_POST_IMM:
|
||||
|
@ -496,6 +496,10 @@ foo2:
|
||||
str r0, [r0, r1]!
|
||||
str r0, [r0], #4
|
||||
str r0, [r0], r1
|
||||
strh r0, [r0, #2]!
|
||||
strh r0, [r0, r1]!
|
||||
strh r0, [r0], #2
|
||||
strh r0, [r0], r1
|
||||
strb r0, [r0, #1]!
|
||||
strb r0, [r0, r1]!
|
||||
strb r0, [r0], #1
|
||||
@ -513,6 +517,18 @@ foo2:
|
||||
@ CHECK-ERRORS: str r0, [r0], r1
|
||||
@ CHECK-ERRORS: ^
|
||||
@ CHECK-ERRORS: error: source register and base register can't be identical
|
||||
@ CHECK-ERRORS: strh r0, [r0, #2]!
|
||||
@ CHECK-ERRORS: ^
|
||||
@ CHECK-ERRORS: error: source register and base register can't be identical
|
||||
@ CHECK-ERRORS: strh r0, [r0, r1]!
|
||||
@ CHECK-ERRORS: ^
|
||||
@ CHECK-ERRORS: error: source register and base register can't be identical
|
||||
@ CHECK-ERRORS: strh r0, [r0], #2
|
||||
@ CHECK-ERRORS: ^
|
||||
@ CHECK-ERRORS: error: source register and base register can't be identical
|
||||
@ CHECK-ERRORS: strh r0, [r0], r1
|
||||
@ CHECK-ERRORS: ^
|
||||
@ CHECK-ERRORS: error: source register and base register can't be identical
|
||||
@ CHECK-ERRORS: strb r0, [r0, #1]!
|
||||
@ CHECK-ERRORS: ^
|
||||
@ CHECK-ERRORS: error: source register and base register can't be identical
|
||||
|
Loading…
x
Reference in New Issue
Block a user