mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-19 06:31:18 +00:00
Thumb2 'add rd, pc, imm' alternate form for 'adr' instruction.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@148601 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4888d5e98c
commit
12a8863828
@ -4180,3 +4180,6 @@ def : t2InstAlias<"ldrsb${p}.w $Rt, $addr",
|
||||
(t2LDRSBpcrel GPRnopc:$Rt, t2ldr_pcrel_imm12:$addr, pred:$p)>;
|
||||
def : t2InstAlias<"ldrsh${p}.w $Rt, $addr",
|
||||
(t2LDRSHpcrel GPRnopc:$Rt, t2ldr_pcrel_imm12:$addr, pred:$p)>;
|
||||
|
||||
def : t2InstAlias<"add${p} $Rd, pc, $imm",
|
||||
(t2ADR rGPR:$Rd, imm0_4095:$imm, pred:$p)>;
|
||||
|
@ -4628,9 +4628,11 @@ bool ARMAsmParser::shouldOmitCCOutOperand(StringRef Mnemonic,
|
||||
//
|
||||
// If either register is a high reg, it's either one of the SP
|
||||
// variants (handled above) or a 32-bit encoding, so we just
|
||||
// check against T3.
|
||||
// check against T3. If the second register is the PC, this is an
|
||||
// alternate form of ADR, which uses encoding T4, so check for that too.
|
||||
if ((!isARMLowRegister(static_cast<ARMOperand*>(Operands[3])->getReg()) ||
|
||||
!isARMLowRegister(static_cast<ARMOperand*>(Operands[4])->getReg())) &&
|
||||
static_cast<ARMOperand*>(Operands[4])->getReg() != ARM::PC &&
|
||||
static_cast<ARMOperand*>(Operands[5])->isT2SOImm())
|
||||
return false;
|
||||
// If both registers are low, we're in an IT block, and the immediate is
|
||||
|
Loading…
x
Reference in New Issue
Block a user