mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 20:51:52 +01:00
MC: Remove unneeded context argument to MCExpr::Evaluate*.
llvm-svn: 84233
This commit is contained in:
parent
af3162e523
commit
022b59a0b5
@ -62,14 +62,14 @@ public:
|
||||
///
|
||||
/// @param Res - The absolute value, if evaluation succeeds.
|
||||
/// @result - True on success.
|
||||
bool EvaluateAsAbsolute(MCContext &Ctx, int64_t &Res) const;
|
||||
bool EvaluateAsAbsolute(int64_t &Res) const;
|
||||
|
||||
/// EvaluateAsRelocatable - Try to evaluate the expression to a relocatable
|
||||
/// value, i.e. an expression of the fixed form (a - b + constant).
|
||||
///
|
||||
/// @param Res - The relocatable value, if evaluation succeeds.
|
||||
/// @result - True on success.
|
||||
bool EvaluateAsRelocatable(MCContext &Ctx, MCValue &Res) const;
|
||||
bool EvaluateAsRelocatable(MCValue &Res) const;
|
||||
|
||||
/// @}
|
||||
|
||||
|
@ -141,10 +141,10 @@ const MCSymbolRefExpr *MCSymbolRefExpr::Create(const StringRef &Name,
|
||||
|
||||
/* *** */
|
||||
|
||||
bool MCExpr::EvaluateAsAbsolute(MCContext &Ctx, int64_t &Res) const {
|
||||
bool MCExpr::EvaluateAsAbsolute(int64_t &Res) const {
|
||||
MCValue Value;
|
||||
|
||||
if (!EvaluateAsRelocatable(Ctx, Value) || !Value.isAbsolute())
|
||||
if (!EvaluateAsRelocatable(Value) || !Value.isAbsolute())
|
||||
return false;
|
||||
|
||||
Res = Value.getConstant();
|
||||
@ -173,7 +173,7 @@ static bool EvaluateSymbolicAdd(const MCValue &LHS, const MCSymbol *RHS_A,
|
||||
return true;
|
||||
}
|
||||
|
||||
bool MCExpr::EvaluateAsRelocatable(MCContext &Ctx, MCValue &Res) const {
|
||||
bool MCExpr::EvaluateAsRelocatable(MCValue &Res) const {
|
||||
switch (getKind()) {
|
||||
case Constant:
|
||||
Res = MCValue::get(cast<MCConstantExpr>(this)->getValue());
|
||||
@ -184,7 +184,7 @@ bool MCExpr::EvaluateAsRelocatable(MCContext &Ctx, MCValue &Res) const {
|
||||
|
||||
// Evaluate recursively if this is a variable.
|
||||
if (Sym.isVariable())
|
||||
return Sym.getValue()->EvaluateAsRelocatable(Ctx, Res);
|
||||
return Sym.getValue()->EvaluateAsRelocatable(Res);
|
||||
|
||||
Res = MCValue::get(&Sym, 0, 0);
|
||||
return true;
|
||||
@ -194,7 +194,7 @@ bool MCExpr::EvaluateAsRelocatable(MCContext &Ctx, MCValue &Res) const {
|
||||
const MCUnaryExpr *AUE = cast<MCUnaryExpr>(this);
|
||||
MCValue Value;
|
||||
|
||||
if (!AUE->getSubExpr()->EvaluateAsRelocatable(Ctx, Value))
|
||||
if (!AUE->getSubExpr()->EvaluateAsRelocatable(Value))
|
||||
return false;
|
||||
|
||||
switch (AUE->getOpcode()) {
|
||||
@ -227,8 +227,8 @@ bool MCExpr::EvaluateAsRelocatable(MCContext &Ctx, MCValue &Res) const {
|
||||
const MCBinaryExpr *ABE = cast<MCBinaryExpr>(this);
|
||||
MCValue LHSValue, RHSValue;
|
||||
|
||||
if (!ABE->getLHS()->EvaluateAsRelocatable(Ctx, LHSValue) ||
|
||||
!ABE->getRHS()->EvaluateAsRelocatable(Ctx, RHSValue))
|
||||
if (!ABE->getLHS()->EvaluateAsRelocatable(LHSValue) ||
|
||||
!ABE->getRHS()->EvaluateAsRelocatable(RHSValue))
|
||||
return false;
|
||||
|
||||
// We only support a few operations on non-constant expressions, handle
|
||||
|
@ -346,8 +346,7 @@ void MCMachOStreamer::EmitValueToOffset(const MCExpr *Offset,
|
||||
unsigned char Value) {
|
||||
MCValue RelocOffset;
|
||||
|
||||
if (!AddValueSymbols(Offset)->EvaluateAsRelocatable(getContext(),
|
||||
RelocOffset))
|
||||
if (!AddValueSymbols(Offset)->EvaluateAsRelocatable(RelocOffset))
|
||||
return llvm_report_error("expected relocatable expression");
|
||||
|
||||
new MCOrgFragment(RelocOffset, Value, CurSectionData);
|
||||
|
@ -292,7 +292,7 @@ bool AsmParser::ParseAbsoluteExpression(int64_t &Res) {
|
||||
if (ParseExpression(Expr))
|
||||
return true;
|
||||
|
||||
if (!Expr->EvaluateAsAbsolute(Ctx, Res))
|
||||
if (!Expr->EvaluateAsAbsolute(Res))
|
||||
return Error(StartLoc, "expected absolute expression");
|
||||
|
||||
return false;
|
||||
|
Loading…
x
Reference in New Issue
Block a user