summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-08-22 08:27:54 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-08-22 08:27:54 +0000
commita5441fea1f5d4f86d6211af16dbf7d190f2a3c83 (patch)
tree96947c5ab1c68c9e7d3020ba19875db180934293 /lib
parent8906ff1b9dfde28f1ff00706643ca10843b26e01 (diff)
downloadllvm-a5441fea1f5d4f86d6211af16dbf7d190f2a3c83.tar.gz
llvm-a5441fea1f5d4f86d6211af16dbf7d190f2a3c83.tar.bz2
llvm-a5441fea1f5d4f86d6211af16dbf7d190f2a3c83.tar.xz
llvm-mc: Rename / redefine MCFragment::FileOffset to MCFragment::Offset (the
section offset). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79734 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/MC/MCAssembler.cpp24
1 files changed, 9 insertions, 15 deletions
diff --git a/lib/MC/MCAssembler.cpp b/lib/MC/MCAssembler.cpp
index 9d8c3c5600..16864f9607 100644
--- a/lib/MC/MCAssembler.cpp
+++ b/lib/MC/MCAssembler.cpp
@@ -202,7 +202,6 @@ MCFragment::MCFragment() : Kind(FragmentType(~0)) {
MCFragment::MCFragment(FragmentType _Kind, MCSectionData *SD)
: Kind(_Kind),
- FileOffset(~UINT64_C(0)),
FileSize(~UINT64_C(0))
{
if (SD)
@@ -234,22 +233,20 @@ MCAssembler::~MCAssembler() {
}
void MCAssembler::LayoutSection(MCSectionData &SD) {
- uint64_t FileOffset = SD.getFileOffset();
- uint64_t SectionOffset = 0;
+ uint64_t Offset = 0;
for (MCSectionData::iterator it = SD.begin(), ie = SD.end(); it != ie; ++it) {
MCFragment &F = *it;
- F.setFileOffset(FileOffset);
+ F.setOffset(Offset);
// Evaluate fragment size.
switch (F.getKind()) {
case MCFragment::FT_Align: {
MCAlignFragment &AF = cast<MCAlignFragment>(F);
- uint64_t AlignedOffset =
- RoundUpToAlignment(SectionOffset, AF.getAlignment());
- uint64_t PaddingBytes = AlignedOffset - SectionOffset;
+ uint64_t AlignedOffset = RoundUpToAlignment(Offset, AF.getAlignment());
+ uint64_t PaddingBytes = AlignedOffset - Offset;
if (PaddingBytes > AF.getMaxBytesToEmit())
AF.setFileSize(0);
@@ -271,21 +268,20 @@ void MCAssembler::LayoutSection(MCSectionData &SD) {
uint64_t OrgOffset = OF.getOffset().getConstant();
// FIXME: We need a way to communicate this error.
- if (OrgOffset < SectionOffset)
+ if (OrgOffset < Offset)
llvm_report_error("invalid .org offset '" + Twine(OrgOffset) +
- "' (section offset '" + Twine(SectionOffset) + "'");
+ "' (section offset '" + Twine(Offset) + "'");
- F.setFileSize(OrgOffset - SectionOffset);
+ F.setFileSize(OrgOffset - Offset);
break;
}
}
- FileOffset += F.getFileSize();
- SectionOffset += F.getFileSize();
+ Offset += F.getFileSize();
}
// FIXME: Pad section?
- SD.setFileSize(FileOffset - SD.getFileOffset());
+ SD.setFileSize(Offset);
}
/// WriteFileData - Write the \arg F data to the output file.
@@ -294,8 +290,6 @@ static void WriteFileData(raw_ostream &OS, const MCFragment &F,
uint64_t Start = OS.tell();
(void) Start;
- assert(F.getFileOffset() == Start && "Invalid file offset!");
-
// FIXME: Embed in fragments instead?
switch (F.getKind()) {
case MCFragment::FT_Align: {