aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-08-27 23:45:06 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-08-27 23:45:06 +0000
commit58b5068b1ac7a1ce4c2eeee30c600d2a5b9e37e0 (patch)
tree07b370e9ca20ac8755027e312dc613f31adf8714
parent7362ce08cb2c1f0b544b18dbc21630fb4baebcfc (diff)
llvm-mc: Unique sections in .zerofill.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@80305 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--tools/llvm-mc/AsmParser.cpp26
1 files changed, 9 insertions, 17 deletions
diff --git a/tools/llvm-mc/AsmParser.cpp b/tools/llvm-mc/AsmParser.cpp
index 2c855d950f..9f219925b0 100644
--- a/tools/llvm-mc/AsmParser.cpp
+++ b/tools/llvm-mc/AsmParser.cpp
@@ -1287,15 +1287,10 @@ bool AsmParser::ParseDirectiveDarwinZerofill() {
// If this is the end of the line all that was wanted was to create the
// the section but with no symbol.
if (Lexer.is(AsmToken::EndOfStatement)) {
- // FIXME: CACHE THIS.
- MCSection *S = 0; //Ctx.GetSection(Section);
- if (S == 0)
- S = MCSectionMachO::Create(Segment, Section,
- MCSectionMachO::S_ZEROFILL, 0,
- SectionKind(), Ctx);
-
// Create the zerofill section but no symbol
- Out.EmitZerofill(S);
+ Out.EmitZerofill(getMachOSection(Segment, Section,
+ MCSectionMachO::S_ZEROFILL, 0,
+ SectionKind()));
return false;
}
@@ -1348,16 +1343,13 @@ bool AsmParser::ParseDirectiveDarwinZerofill() {
if (!Sym->isUndefined())
return Error(IDLoc, "invalid symbol redefinition");
- // FIXME: Arch specific.
- // FIXME: CACHE.
- MCSection *S = 0; //Ctx.GetSection(Section);
- if (S == 0)
- S = MCSectionMachO::Create(Segment, Section,
- MCSectionMachO::S_ZEROFILL, 0,
- SectionKind(), Ctx);
-
// Create the zerofill Symbol with Size and Pow2Alignment
- Out.EmitZerofill(S, Sym, Size, Pow2Alignment);
+ //
+ // FIXME: Arch specific.
+ Out.EmitZerofill(getMachOSection(Segment, Section,
+ MCSectionMachO::S_ZEROFILL, 0,
+ SectionKind()),
+ Sym, Size, Pow2Alignment);
return false;
}