summaryrefslogtreecommitdiffstats
path: root/llvm/tools
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-08-21 23:30:15 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-08-21 23:30:15 +0000
commit67dfb1de236dada2cc019b665203d216e4441b43 (patch)
tree5cbb38cdd035445b229122619f35660b95c501ce /llvm/tools
parente64061f6758d245a80354dadc0bbfde6e24ec6c1 (diff)
downloadbcm5719-llvm-67dfb1de236dada2cc019b665203d216e4441b43.tar.gz
bcm5719-llvm-67dfb1de236dada2cc019b665203d216e4441b43.zip
llvm-mc: Improve handling of implicit alignment for magic section directives
(e.g., .objc_message_refs). - Just emit a .align when we see the directive; this isn't exactly what 'as' does but in practice it should be ok, at least for now. See FIXME. llvm-svn: 79697
Diffstat (limited to 'llvm/tools')
-rw-r--r--llvm/tools/llvm-mc/AsmParser.cpp13
1 files changed, 12 insertions, 1 deletions
diff --git a/llvm/tools/llvm-mc/AsmParser.cpp b/llvm/tools/llvm-mc/AsmParser.cpp
index 9db0ac0351b..19781212976 100644
--- a/llvm/tools/llvm-mc/AsmParser.cpp
+++ b/llvm/tools/llvm-mc/AsmParser.cpp
@@ -794,13 +794,24 @@ bool AsmParser::ParseDirectiveSectionSwitch(const char *Segment,
// FIXME: Arch specific.
// FIXME: Cache this!
- // FIXME: Handle the implicit alignment!!
MCSection *S = 0; // Ctx.GetSection(Section);
if (S == 0)
S = MCSectionMachO::Create(Segment, Section, TAA, StubSize,
SectionKind(), Ctx);
Out.SwitchSection(S);
+
+ // Set the implicit alignment, if any.
+ //
+ // FIXME: This isn't really what 'as' does; I think it just uses the implicit
+ // alignment on the section (e.g., if one manually inserts bytes into the
+ // section, then just issueing the section switch directive will not realign
+ // the section. However, this is arguably more reasonable behavior, and there
+ // is no good reason for someone to intentionally emit incorrectly sized
+ // values into the implicitly aligned sections.
+ if (Align)
+ Out.EmitValueToAlignment(Align, 0, 1, 0);
+
return false;
}
OpenPOWER on IntegriCloud