mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 19:52:54 +01:00
Revert r122359 while I debug PR8845.
llvm-svn: 122427
This commit is contained in:
parent
2a54f466cf
commit
6baac40d13
@ -269,13 +269,27 @@ bool MCExpr::EvaluateAsAbsolute(int64_t &Res, const MCAssembler *Asm,
|
|||||||
// FIXME: The use if InSet = Addrs is a hack. Setting InSet causes us
|
// FIXME: The use if InSet = Addrs is a hack. Setting InSet causes us
|
||||||
// absolutize differences across sections and that is what the MachO writer
|
// absolutize differences across sections and that is what the MachO writer
|
||||||
// uses Addrs for.
|
// uses Addrs for.
|
||||||
bool IsRelocatable =
|
if (!EvaluateAsRelocatableImpl(Value, Asm, Layout, Addrs, /*InSet*/ Addrs) ||
|
||||||
EvaluateAsRelocatableImpl(Value, Asm, Layout, Addrs, /*InSet*/ Addrs);
|
!Value.isAbsolute()) {
|
||||||
|
// EvaluateAsAbsolute is defined to return the "current value" of
|
||||||
|
// the expression if we are given a Layout object, even in cases
|
||||||
|
// when the value is not fixed.
|
||||||
|
if (Layout) {
|
||||||
|
Res = Value.getConstant();
|
||||||
|
if (Value.getSymA()) {
|
||||||
|
Res += Layout->getSymbolOffset(
|
||||||
|
&Layout->getAssembler().getSymbolData(Value.getSymA()->getSymbol()));
|
||||||
|
}
|
||||||
|
if (Value.getSymB()) {
|
||||||
|
Res -= Layout->getSymbolOffset(
|
||||||
|
&Layout->getAssembler().getSymbolData(Value.getSymB()->getSymbol()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Record the current value.
|
|
||||||
Res = Value.getConstant();
|
Res = Value.getConstant();
|
||||||
|
return true;
|
||||||
return IsRelocatable && Value.isAbsolute();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// \brief Helper method for \see EvaluateSymbolAdd().
|
/// \brief Helper method for \see EvaluateSymbolAdd().
|
||||||
|
Loading…
Reference in New Issue
Block a user