aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2010-12-22 22:04:28 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2010-12-22 22:04:28 +0000
commit835439a397407e421263bd476e5b18bf787ffb6a (patch)
treebd06b710ca9e953666014c4e82099182e06c4978
parent770d42de3b7643b2b4f835f32e3a16275b9fbdba (diff)
downloadexternal_llvm-835439a397407e421263bd476e5b18bf787ffb6a.zip
external_llvm-835439a397407e421263bd476e5b18bf787ffb6a.tar.gz
external_llvm-835439a397407e421263bd476e5b18bf787ffb6a.tar.bz2
Assert that the AddrDelta expression is really constant and wrap it in a set
if we have a lame assembler. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122446 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/MC/MCAssembler.cpp4
-rw-r--r--lib/MC/MCObjectStreamer.cpp8
2 files changed, 10 insertions, 2 deletions
diff --git a/lib/MC/MCAssembler.cpp b/lib/MC/MCAssembler.cpp
index bff8836..3fd0c53 100644
--- a/lib/MC/MCAssembler.cpp
+++ b/lib/MC/MCAssembler.cpp
@@ -687,7 +687,9 @@ bool MCAssembler::RelaxDwarfLineAddr(MCAsmLayout &Layout,
MCDwarfLineAddrFragment &DF) {
int64_t AddrDelta = 0;
uint64_t OldSize = DF.getContents().size();
- DF.getAddrDelta().EvaluateAsAbsolute(AddrDelta, Layout);
+ bool IsAbs = DF.getAddrDelta().EvaluateAsAbsolute(AddrDelta, Layout);
+ (void)IsAbs;
+ assert(IsAbs);
int64_t LineDelta;
LineDelta = DF.getLineDelta();
SmallString<8> &Data = DF.getContents();
diff --git a/lib/MC/MCObjectStreamer.cpp b/lib/MC/MCObjectStreamer.cpp
index cbc66f1..af102ec 100644
--- a/lib/MC/MCObjectStreamer.cpp
+++ b/lib/MC/MCObjectStreamer.cpp
@@ -7,6 +7,7 @@
//
//===----------------------------------------------------------------------===//
+#include "llvm/MC/MCAsmInfo.h"
#include "llvm/MC/MCObjectStreamer.h"
#include "llvm/Support/ErrorHandling.h"
@@ -90,7 +91,7 @@ void MCObjectStreamer::EmitValueImpl(const MCExpr *Value, unsigned Size,
return;
}
DF->addFixup(MCFixup::Create(DF->getContents().size(),
- AddValueSymbols(Value),
+ Value,
MCFixup::getKindForSize(Size, isPCRel)));
DF->getContents().resize(DF->getContents().size() + Size, 0);
}
@@ -210,6 +211,11 @@ void MCObjectStreamer::EmitDwarfAdvanceLineAddr(int64_t LineDelta,
MCDwarfLineAddr::Emit(this, LineDelta, Res);
return;
}
+ if (!getContext().getAsmInfo().hasAggressiveSymbolFolding()) {
+ MCSymbol *ABS = getContext().CreateTempSymbol();
+ EmitAssignment(ABS, AddrDelta);
+ AddrDelta = MCSymbolRefExpr::Create(ABS, getContext());
+ }
new MCDwarfLineAddrFragment(LineDelta, *AddrDelta, getCurrentSectionData());
}