mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-25 04:39:44 +00:00
[ms-inline asm] Perform field lookups with the dot operator.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@166724 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b6cbb6215c
commit
ec13022c39
@ -37,6 +37,8 @@ public:
|
||||
virtual ~MCAsmParserSemaCallback();
|
||||
virtual void *LookupInlineAsmIdentifier(StringRef Name, void *Loc,
|
||||
unsigned &Size) = 0;
|
||||
virtual bool LookupInlineAsmField(StringRef Base, StringRef Member,
|
||||
unsigned &Offset) = 0;
|
||||
};
|
||||
|
||||
/// MCAsmParser - Generic assembler parser interface, for use by target specific
|
||||
|
@ -841,15 +841,30 @@ bool X86AsmParser::ParseIntelDotOperator(const MCExpr *Disp,
|
||||
APInt DotDisp;
|
||||
DotDispStr.getAsInteger(10, DotDisp);
|
||||
DotDispVal = DotDisp.getZExtValue();
|
||||
} else if (Tok.is(AsmToken::Identifier)) {
|
||||
// We should only see an identifier when parsing the original inline asm.
|
||||
// The front-end should rewrite this in terms of immediates.
|
||||
assert (isParsingInlineAsm() && "Unexpected field name!");
|
||||
|
||||
unsigned DotDisp;
|
||||
std::pair<StringRef, StringRef> BaseMember = DotDispStr.split('.');
|
||||
if (SemaCallback->LookupInlineAsmField(BaseMember.first, BaseMember.second,
|
||||
DotDisp)) {
|
||||
Err = "Unable to lookup field reference!";
|
||||
return true;
|
||||
}
|
||||
DotDispVal = DotDisp;
|
||||
} else {
|
||||
Err = "Unexpected token type!";
|
||||
return true;
|
||||
}
|
||||
|
||||
// Special case zero dot displacement.
|
||||
if (!DotDispVal) {
|
||||
*NewDisp = Disp;
|
||||
return false;
|
||||
if (isParsingInlineAsm() && Tok.is(AsmToken::Identifier)) {
|
||||
SMLoc Loc = SMLoc::getFromPointer(DotDispStr.data());
|
||||
unsigned Len = DotDispStr.size();
|
||||
unsigned Val = OrigDispVal + DotDispVal;
|
||||
InstInfo->AsmRewrites->push_back(AsmRewrite(AOK_DotOperator, Loc, Len,
|
||||
Val));
|
||||
}
|
||||
|
||||
*NewDisp = MCConstantExpr::Create(OrigDispVal + DotDispVal, getContext());
|
||||
|
Loading…
Reference in New Issue
Block a user