mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-26 04:34:41 +00:00
McARM: Unify ParseMemory() successfull return.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@123740 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0571093f4c
commit
05d8b71424
@ -720,17 +720,19 @@ ParseMemory(SmallVectorImpl<MCParsedAsmOperand*> &Operands) {
|
|||||||
bool OffsetIsReg = false;
|
bool OffsetIsReg = false;
|
||||||
bool Negative = false;
|
bool Negative = false;
|
||||||
bool Writeback = false;
|
bool Writeback = false;
|
||||||
|
ARMOperand *WBOp = 0;
|
||||||
|
int OffsetRegNum = -1;
|
||||||
|
bool OffsetRegShifted = false;
|
||||||
|
enum ShiftType ShiftType = Lsl;
|
||||||
|
const MCExpr *ShiftAmount = 0;
|
||||||
|
const MCExpr *Offset = 0;
|
||||||
|
|
||||||
// First look for preindexed address forms, that is after the "[Rn" we now
|
// First look for preindexed address forms, that is after the "[Rn" we now
|
||||||
// have to see if the next token is a comma.
|
// have to see if the next token is a comma.
|
||||||
if (Tok.is(AsmToken::Comma)) {
|
if (Tok.is(AsmToken::Comma)) {
|
||||||
Preindexed = true;
|
Preindexed = true;
|
||||||
Parser.Lex(); // Eat comma token.
|
Parser.Lex(); // Eat comma token.
|
||||||
int OffsetRegNum;
|
|
||||||
bool OffsetRegShifted;
|
|
||||||
enum ShiftType ShiftType;
|
|
||||||
const MCExpr *ShiftAmount = 0;
|
|
||||||
const MCExpr *Offset = 0;
|
|
||||||
if (ParseMemoryOffsetReg(Negative, OffsetRegShifted, ShiftType, ShiftAmount,
|
if (ParseMemoryOffsetReg(Negative, OffsetRegShifted, ShiftType, ShiftAmount,
|
||||||
Offset, OffsetIsReg, OffsetRegNum, E))
|
Offset, OffsetIsReg, OffsetRegNum, E))
|
||||||
return true;
|
return true;
|
||||||
@ -743,29 +745,12 @@ ParseMemory(SmallVectorImpl<MCParsedAsmOperand*> &Operands) {
|
|||||||
Parser.Lex(); // Eat right bracket token.
|
Parser.Lex(); // Eat right bracket token.
|
||||||
|
|
||||||
const AsmToken &ExclaimTok = Parser.getTok();
|
const AsmToken &ExclaimTok = Parser.getTok();
|
||||||
ARMOperand *WBOp = 0;
|
|
||||||
if (ExclaimTok.is(AsmToken::Exclaim)) {
|
if (ExclaimTok.is(AsmToken::Exclaim)) {
|
||||||
WBOp = ARMOperand::CreateToken(ExclaimTok.getString(),
|
WBOp = ARMOperand::CreateToken(ExclaimTok.getString(),
|
||||||
ExclaimTok.getLoc());
|
ExclaimTok.getLoc());
|
||||||
Writeback = true;
|
Writeback = true;
|
||||||
Parser.Lex(); // Eat exclaim token
|
Parser.Lex(); // Eat exclaim token
|
||||||
}
|
}
|
||||||
|
|
||||||
// Force Offset to exist if used.
|
|
||||||
if (!OffsetIsReg) {
|
|
||||||
if (!Offset)
|
|
||||||
Offset = MCConstantExpr::Create(0, getContext());
|
|
||||||
}
|
|
||||||
|
|
||||||
Operands.push_back(ARMOperand::CreateMem(BaseRegNum, OffsetIsReg, Offset,
|
|
||||||
OffsetRegNum, OffsetRegShifted,
|
|
||||||
ShiftType, ShiftAmount, Preindexed,
|
|
||||||
Postindexed, Negative, Writeback,
|
|
||||||
S, E));
|
|
||||||
if (WBOp)
|
|
||||||
Operands.push_back(WBOp);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
} else {
|
} else {
|
||||||
// The "[Rn" we have so far was not followed by a comma.
|
// The "[Rn" we have so far was not followed by a comma.
|
||||||
|
|
||||||
@ -774,12 +759,6 @@ ParseMemory(SmallVectorImpl<MCParsedAsmOperand*> &Operands) {
|
|||||||
E = Tok.getLoc();
|
E = Tok.getLoc();
|
||||||
Parser.Lex(); // Eat right bracket token.
|
Parser.Lex(); // Eat right bracket token.
|
||||||
|
|
||||||
int OffsetRegNum = -1;
|
|
||||||
bool OffsetRegShifted = false;
|
|
||||||
enum ShiftType ShiftType = Lsl;
|
|
||||||
const MCExpr *ShiftAmount = 0;
|
|
||||||
const MCExpr *Offset = 0;
|
|
||||||
|
|
||||||
const AsmToken &NextTok = Parser.getTok();
|
const AsmToken &NextTok = Parser.getTok();
|
||||||
|
|
||||||
if (NextTok.isNot(AsmToken::EndOfStatement)) {
|
if (NextTok.isNot(AsmToken::EndOfStatement)) {
|
||||||
@ -798,20 +777,23 @@ ParseMemory(SmallVectorImpl<MCParsedAsmOperand*> &Operands) {
|
|||||||
E))
|
E))
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Force Offset to exist if used.
|
|
||||||
if (!OffsetIsReg) {
|
|
||||||
if (!Offset)
|
|
||||||
Offset = MCConstantExpr::Create(0, getContext());
|
|
||||||
}
|
|
||||||
|
|
||||||
Operands.push_back(ARMOperand::CreateMem(BaseRegNum, OffsetIsReg, Offset,
|
|
||||||
OffsetRegNum, OffsetRegShifted,
|
|
||||||
ShiftType, ShiftAmount, Preindexed,
|
|
||||||
Postindexed, Negative, Writeback,
|
|
||||||
S, E));
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Force Offset to exist if used.
|
||||||
|
if (!OffsetIsReg) {
|
||||||
|
if (!Offset)
|
||||||
|
Offset = MCConstantExpr::Create(0, getContext());
|
||||||
|
}
|
||||||
|
|
||||||
|
Operands.push_back(ARMOperand::CreateMem(BaseRegNum, OffsetIsReg, Offset,
|
||||||
|
OffsetRegNum, OffsetRegShifted,
|
||||||
|
ShiftType, ShiftAmount, Preindexed,
|
||||||
|
Postindexed, Negative, Writeback,
|
||||||
|
S, E));
|
||||||
|
if (WBOp)
|
||||||
|
Operands.push_back(WBOp);
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Parse the offset of a memory operand after we have seen "[Rn," or "[Rn],"
|
/// Parse the offset of a memory operand after we have seen "[Rn," or "[Rn],"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user