mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 11:42:57 +01:00
Add support for parsing #-0 on non-memory-operand immediate values, and add a testcase that necessitates it.
llvm-svn: 138739
This commit is contained in:
parent
026fa4da72
commit
8719e2c1c3
@ -717,7 +717,7 @@ public:
|
|||||||
const MCConstantExpr *CE = dyn_cast<MCConstantExpr>(getImm());
|
const MCConstantExpr *CE = dyn_cast<MCConstantExpr>(getImm());
|
||||||
if (!CE) return false;
|
if (!CE) return false;
|
||||||
int64_t Val = CE->getValue();
|
int64_t Val = CE->getValue();
|
||||||
return Val > -256 && Val < 256;
|
return (Val > -256 && Val < 256) || (Val == INT32_MIN);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool isMSRMask() const { return Kind == MSRMask; }
|
bool isMSRMask() const { return Kind == MSRMask; }
|
||||||
@ -1106,6 +1106,7 @@ public:
|
|||||||
assert(CE && "non-constant post-idx-imm8 operand!");
|
assert(CE && "non-constant post-idx-imm8 operand!");
|
||||||
int Imm = CE->getValue();
|
int Imm = CE->getValue();
|
||||||
bool isAdd = Imm >= 0;
|
bool isAdd = Imm >= 0;
|
||||||
|
if (Imm == INT32_MIN) Imm = 0;
|
||||||
Imm = (Imm < 0 ? -Imm : Imm) | (int)isAdd << 8;
|
Imm = (Imm < 0 ? -Imm : Imm) | (int)isAdd << 8;
|
||||||
Inst.addOperand(MCOperand::CreateImm(Imm));
|
Inst.addOperand(MCOperand::CreateImm(Imm));
|
||||||
}
|
}
|
||||||
@ -2746,17 +2747,27 @@ bool ARMAsmParser::parseOperand(SmallVectorImpl<MCParsedAsmOperand*> &Operands,
|
|||||||
return parseMemory(Operands);
|
return parseMemory(Operands);
|
||||||
case AsmToken::LCurly:
|
case AsmToken::LCurly:
|
||||||
return parseRegisterList(Operands);
|
return parseRegisterList(Operands);
|
||||||
case AsmToken::Hash:
|
case AsmToken::Hash: {
|
||||||
// #42 -> immediate.
|
// #42 -> immediate.
|
||||||
// TODO: ":lower16:" and ":upper16:" modifiers after # before immediate
|
// TODO: ":lower16:" and ":upper16:" modifiers after # before immediate
|
||||||
S = Parser.getTok().getLoc();
|
S = Parser.getTok().getLoc();
|
||||||
Parser.Lex();
|
Parser.Lex();
|
||||||
|
bool isNegative = Parser.getTok().is(AsmToken::Minus);
|
||||||
const MCExpr *ImmVal;
|
const MCExpr *ImmVal;
|
||||||
if (getParser().ParseExpression(ImmVal))
|
if (getParser().ParseExpression(ImmVal))
|
||||||
return true;
|
return true;
|
||||||
|
const MCConstantExpr *CE = dyn_cast<MCConstantExpr>(ImmVal);
|
||||||
|
if (!CE) {
|
||||||
|
Error(S, "constant expression expected");
|
||||||
|
return MatchOperand_ParseFail;
|
||||||
|
}
|
||||||
|
int32_t Val = CE->getValue();
|
||||||
|
if (isNegative && Val == 0)
|
||||||
|
ImmVal = MCConstantExpr::Create(INT32_MIN, getContext());
|
||||||
E = SMLoc::getFromPointer(Parser.getTok().getLoc().getPointer() - 1);
|
E = SMLoc::getFromPointer(Parser.getTok().getLoc().getPointer() - 1);
|
||||||
Operands.push_back(ARMOperand::CreateImm(ImmVal, S, E));
|
Operands.push_back(ARMOperand::CreateImm(ImmVal, S, E));
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
case AsmToken::Colon: {
|
case AsmToken::Colon: {
|
||||||
// ":lower16:" and ":upper16:" expression prefixes
|
// ":lower16:" and ":upper16:" expression prefixes
|
||||||
// FIXME: Check it's an expression prefix,
|
// FIXME: Check it's an expression prefix,
|
||||||
|
@ -687,6 +687,14 @@ Lforward:
|
|||||||
@ CHECK: ldrex r1, [r7] @ encoding: [0x9f,0x1f,0x97,0xe1]
|
@ CHECK: ldrex r1, [r7] @ encoding: [0x9f,0x1f,0x97,0xe1]
|
||||||
@ CHECK: ldrexd r6, r7, [r8] @ encoding: [0x9f,0x6f,0xb8,0xe1]
|
@ CHECK: ldrexd r6, r7, [r8] @ encoding: [0x9f,0x6f,0xb8,0xe1]
|
||||||
|
|
||||||
|
@------------------------------------------------------------------------------
|
||||||
|
@ LDRHT
|
||||||
|
@------------------------------------------------------------------------------
|
||||||
|
ldrhthi r8, [r11], #-0
|
||||||
|
ldrhthi r8, [r11], #0
|
||||||
|
|
||||||
|
@ CHECK: ldrhthi r8, [r11], #-0 @ encoding: [0xb0,0x80,0x7b,0x80]
|
||||||
|
@ CHECK: ldrhthi r8, [r11], #0 @ encoding: [0xb0,0x80,0xfb,0x80]
|
||||||
|
|
||||||
@------------------------------------------------------------------------------
|
@------------------------------------------------------------------------------
|
||||||
@ FIXME: LSL
|
@ FIXME: LSL
|
||||||
|
Loading…
Reference in New Issue
Block a user