aboutsummaryrefslogtreecommitdiffstats
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
commit2330df6b66e6ca7cfad54be9088f0d931cc66441 (patch)
tree0f11e02054811d0ff4ac85eed9115585f938481d
parenta887ae4608c97f75feae6c89af33ecc2eadbc210 (diff)
downloadexternal_llvm-2330df6b66e6ca7cfad54be9088f0d931cc66441.zip
external_llvm-2330df6b66e6ca7cfad54be9088f0d931cc66441.tar.gz
external_llvm-2330df6b66e6ca7cfad54be9088f0d931cc66441.tar.bz2
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. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79697 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--test/MC/MachO/sections.s27
-rw-r--r--tools/llvm-mc/AsmParser.cpp13
2 files changed, 21 insertions, 19 deletions
diff --git a/test/MC/MachO/sections.s b/test/MC/MachO/sections.s
index 7b7f9a1..9771602 100644
--- a/test/MC/MachO/sections.s
+++ b/test/MC/MachO/sections.s
@@ -121,8 +121,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 2)
+// CHECK: ('alignment', 2)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0x3)
@@ -135,8 +134,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 3)
+// CHECK: ('alignment', 3)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0x4)
@@ -149,8 +147,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 4)
+// CHECK: ('alignment', 4)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0xe)
@@ -241,8 +238,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 2)
+// CHECK: ('alignment', 2)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0x6)
@@ -255,8 +251,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 2)
+// CHECK: ('alignment', 2)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0x7)
@@ -282,8 +277,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 2)
+// CHECK: ('alignment', 2)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0x9)
@@ -296,8 +290,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 2)
+// CHECK: ('alignment', 2)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0xa)
@@ -427,8 +420,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 2)
+// CHECK: ('alignment', 2)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0x10000005)
@@ -441,8 +433,7 @@
// CHECK: ('address', 0)
// CHECK: ('size', 0)
// CHECK: ('offset', 2464)
- // FIXME: We aren't setting alignment correctly yet.
-// CHECX: ('alignment', 2)
+// CHECK: ('alignment', 2)
// CHECK: ('reloc_offset', 0)
// CHECK: ('num_reloc', 0)
// CHECK: ('flags', 0x10000005)
diff --git a/tools/llvm-mc/AsmParser.cpp b/tools/llvm-mc/AsmParser.cpp
index 9db0ac0..1978121 100644
--- a/tools/llvm-mc/AsmParser.cpp
+++ b/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;
}