summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2010-05-13 08:43:34 +0000
committerDaniel Dunbar <daniel@zuster.org>2010-05-13 08:43:34 +0000
commit09d3465f0e4e5bb1bb858e0e4dececf4f7ab6741 (patch)
treee883710bc16084578f1ee3e159bafddeed887441 /lib
parentaa0d350fe54b0bf13947cdb08d8e76e4ec233d6f (diff)
downloadllvm-09d3465f0e4e5bb1bb858e0e4dececf4f7ab6741.tar.gz
llvm-09d3465f0e4e5bb1bb858e0e4dececf4f7ab6741.tar.bz2
llvm-09d3465f0e4e5bb1bb858e0e4dececf4f7ab6741.tar.xz
MC: Create dummy fragments to avoid ever having empty sections, which simplifies layout.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103710 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/MC/MCAssembler.cpp17
1 files changed, 9 insertions, 8 deletions
diff --git a/lib/MC/MCAssembler.cpp b/lib/MC/MCAssembler.cpp
index de36c52c68..291ae85895 100644
--- a/lib/MC/MCAssembler.cpp
+++ b/lib/MC/MCAssembler.cpp
@@ -116,10 +116,6 @@ void MCAsmLayout::setSectionAddress(MCSectionData *SD, uint64_t Value) {
}
uint64_t MCAsmLayout::getSectionAddressSize(const MCSectionData *SD) const {
- // Empty sections have no size.
- if (SD->getFragmentList().empty())
- return 0;
-
// Otherwise, the size is the last fragment's end offset.
const MCFragment &F = SD->getFragmentList().back();
return getFragmentOffset(&F) + getFragmentEffectiveSize(&F);
@@ -135,10 +131,6 @@ uint64_t MCAsmLayout::getSectionFileSize(const MCSectionData *SD) const {
}
uint64_t MCAsmLayout::getSectionSize(const MCSectionData *SD) const {
- // Empty sections have no size.
- if (SD->getFragmentList().empty())
- return 0;
-
// The logical size is the address space size minus any tail padding.
uint64_t Size = getSectionAddressSize(SD);
const MCAlignFragment *AF =
@@ -611,6 +603,15 @@ void MCAssembler::Finish() {
unsigned SectionIndex = 0;
unsigned FragmentIndex = 0;
for (MCAssembler::iterator it = begin(), ie = end(); it != ie; ++it) {
+ // Create dummy fragments to eliminate any empty sections, this simplifies
+ // layout.
+ if (it->getFragmentList().empty()) {
+ unsigned ValueSize = 1;
+ if (getBackend().isVirtualSection(it->getSection()))
+ ValueSize = 1;
+ new MCFillFragment(0, 1, 0, it);
+ }
+
it->setOrdinal(SectionIndex++);
for (MCSectionData::iterator it2 = it->begin(),