mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-05 13:26:55 +00:00
Given target assembler parsers a chance to handle variant expressions
first. Use this to turn the PPC modifiers into PPC specific expressions, allowing them to work on constants. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@189400 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -235,6 +235,10 @@ public:
|
||||
virtual bool ParseDirective(AsmToken DirectiveID);
|
||||
|
||||
unsigned validateTargetOperandClass(MCParsedAsmOperand *Op, unsigned Kind);
|
||||
|
||||
virtual const MCExpr *applyModifierToExpr(const MCExpr *E,
|
||||
MCSymbolRefExpr::VariantKind,
|
||||
MCContext &Ctx);
|
||||
};
|
||||
|
||||
/// PPCOperand - Instances of this class represent a parsed PowerPC machine
|
||||
@@ -1363,3 +1367,26 @@ unsigned PPCAsmParser::validateTargetOperandClass(MCParsedAsmOperand *AsmOp,
|
||||
return Match_InvalidOperand;
|
||||
}
|
||||
|
||||
const MCExpr *
|
||||
PPCAsmParser::applyModifierToExpr(const MCExpr *E,
|
||||
MCSymbolRefExpr::VariantKind Variant,
|
||||
MCContext &Ctx) {
|
||||
switch (Variant) {
|
||||
case MCSymbolRefExpr::VK_PPC_LO:
|
||||
return PPCMCExpr::Create(PPCMCExpr::VK_PPC_LO, E, false, Ctx);
|
||||
case MCSymbolRefExpr::VK_PPC_HI:
|
||||
return PPCMCExpr::Create(PPCMCExpr::VK_PPC_HI, E, false, Ctx);
|
||||
case MCSymbolRefExpr::VK_PPC_HA:
|
||||
return PPCMCExpr::Create(PPCMCExpr::VK_PPC_HA, E, false, Ctx);
|
||||
case MCSymbolRefExpr::VK_PPC_HIGHER:
|
||||
return PPCMCExpr::Create(PPCMCExpr::VK_PPC_HIGHER, E, false, Ctx);
|
||||
case MCSymbolRefExpr::VK_PPC_HIGHERA:
|
||||
return PPCMCExpr::Create(PPCMCExpr::VK_PPC_HIGHERA, E, false, Ctx);
|
||||
case MCSymbolRefExpr::VK_PPC_HIGHEST:
|
||||
return PPCMCExpr::Create(PPCMCExpr::VK_PPC_HIGHEST, E, false, Ctx);
|
||||
case MCSymbolRefExpr::VK_PPC_HIGHESTA:
|
||||
return PPCMCExpr::Create(PPCMCExpr::VK_PPC_HIGHESTA, E, false, Ctx);
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
@@ -54,7 +54,7 @@ PPCMCExpr::EvaluateAsRelocatableImpl(MCValue &Res,
|
||||
const MCAsmLayout *Layout) const {
|
||||
MCValue Value;
|
||||
|
||||
if (!getSubExpr()->EvaluateAsRelocatable(Value, *Layout))
|
||||
if (Layout && !getSubExpr()->EvaluateAsRelocatable(Value, *Layout))
|
||||
return false;
|
||||
|
||||
if (Value.isAbsolute()) {
|
||||
@@ -85,7 +85,7 @@ PPCMCExpr::EvaluateAsRelocatableImpl(MCValue &Res,
|
||||
break;
|
||||
}
|
||||
Res = MCValue::get(Result);
|
||||
} else {
|
||||
} else if (Layout) {
|
||||
MCContext &Context = Layout->getAssembler().getContext();
|
||||
const MCSymbolRefExpr *Sym = Value.getSymA();
|
||||
MCSymbolRefExpr::VariantKind Modifier = Sym->getKind();
|
||||
@@ -118,7 +118,8 @@ PPCMCExpr::EvaluateAsRelocatableImpl(MCValue &Res,
|
||||
}
|
||||
Sym = MCSymbolRefExpr::Create(&Sym->getSymbol(), Modifier, Context);
|
||||
Res = MCValue::get(Sym, Value.getSymB(), Value.getConstant());
|
||||
}
|
||||
} else
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
Reference in New Issue
Block a user