mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-16 14:31:59 +00:00
Add support for Thumb2 literal loads with negative zero offset
Thumb2 literal loads use an offset encoding which allows for negative zero. This fixes parsing and encoding so that #-0 is correctly processed. The parser represents #-0 as INT32_MIN. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@188549 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
8b36f9e431
commit
e97fc44045
@ -1793,8 +1793,6 @@ public:
|
|||||||
void addMemPCRelImm12Operands(MCInst &Inst, unsigned N) const {
|
void addMemPCRelImm12Operands(MCInst &Inst, unsigned N) const {
|
||||||
assert(N == 1 && "Invalid number of operands!");
|
assert(N == 1 && "Invalid number of operands!");
|
||||||
int32_t Imm = Memory.OffsetImm->getValue();
|
int32_t Imm = Memory.OffsetImm->getValue();
|
||||||
// FIXME: Handle #-0
|
|
||||||
if (Imm == INT32_MIN) Imm = 0;
|
|
||||||
Inst.addOperand(MCOperand::CreateImm(Imm));
|
Inst.addOperand(MCOperand::CreateImm(Imm));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -778,8 +778,10 @@ getAddrModeImm12OpValue(const MCInst &MI, unsigned OpIdx,
|
|||||||
} else {
|
} else {
|
||||||
Reg = ARM::PC;
|
Reg = ARM::PC;
|
||||||
int32_t Offset = MO.getImm();
|
int32_t Offset = MO.getImm();
|
||||||
// FIXME: Handle #-0.
|
if (Offset == INT32_MIN) {
|
||||||
if (Offset < 0) {
|
Offset = 0;
|
||||||
|
isAdd = false;
|
||||||
|
} else if (Offset < 0) {
|
||||||
Offset *= -1;
|
Offset *= -1;
|
||||||
isAdd = false;
|
isAdd = false;
|
||||||
}
|
}
|
||||||
|
@ -830,6 +830,18 @@ _func:
|
|||||||
@ CHECK: ldr.w pc, [pc, #256] @ encoding: [0xdf,0xf8,0x00,0xf1]
|
@ CHECK: ldr.w pc, [pc, #256] @ encoding: [0xdf,0xf8,0x00,0xf1]
|
||||||
@ CHECK: ldr.w pc, [pc, #-400] @ encoding: [0x5f,0xf8,0x90,0xf1]
|
@ CHECK: ldr.w pc, [pc, #-400] @ encoding: [0x5f,0xf8,0x90,0xf1]
|
||||||
|
|
||||||
|
ldrb r9, [pc, #-0]
|
||||||
|
ldrsb r11, [pc, #-0]
|
||||||
|
ldrh r10, [pc, #-0]
|
||||||
|
ldrsh r1, [pc, #-0]
|
||||||
|
ldr r5, [pc, #-0]
|
||||||
|
|
||||||
|
@ CHECK: ldrb.w r9, [pc, #-0] @ encoding: [0x1f,0xf8,0x00,0x90]
|
||||||
|
@ CHECK: ldrsb.w r11, [pc, #-0] @ encoding: [0x1f,0xf9,0x00,0xb0]
|
||||||
|
@ CHECK: ldrh.w r10, [pc, #-0] @ encoding: [0x3f,0xf8,0x00,0xa0]
|
||||||
|
@ CHECK: ldrsh.w r1, [pc, #-0] @ encoding: [0x3f,0xf9,0x00,0x10]
|
||||||
|
@ CHECK: ldr.w r5, [pc, #-0] @ encoding: [0x5f,0xf8,0x00,0x50]
|
||||||
|
|
||||||
@------------------------------------------------------------------------------
|
@------------------------------------------------------------------------------
|
||||||
@ LDR(register)
|
@ LDR(register)
|
||||||
@------------------------------------------------------------------------------
|
@------------------------------------------------------------------------------
|
||||||
|
Loading…
x
Reference in New Issue
Block a user