[llvm-commits] [llvm] r78007 - /llvm/trunk/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp
Chris Lattner
sabre at nondot.org
Mon Aug 3 15:18:16 PDT 2009
Author: lattner
Date: Mon Aug 3 17:18:15 2009
New Revision: 78007
URL: http://llvm.org/viewvc/llvm-project?rev=78007&view=rev
Log:
convert macho stub emission to use SwitchToSection instead of
textual sections.
Modified:
llvm/trunk/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp
Modified: llvm/trunk/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp?rev=78007&r1=78006&r2=78007&view=diff
==============================================================================
--- llvm/trunk/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp (original)
+++ llvm/trunk/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp Mon Aug 3 17:18:15 2009
@@ -1269,49 +1269,65 @@
bool ARMAsmPrinter::doFinalization(Module &M) {
if (Subtarget->isTargetDarwin()) {
- SwitchToDataSection("");
-
+ // All darwin targets use mach-o.
+ TargetLoweringObjectFileMachO &TLOFMacho =
+ static_cast<TargetLoweringObjectFileMachO &>(getObjFileLowering());
+
O << '\n';
- // Output stubs for dynamically-linked functions
- for (StringMap<FnStubInfo>::iterator I = FnStubs.begin(), E = FnStubs.end();
- I != E; ++I) {
- const FnStubInfo &Info = I->second;
+
+ if (!FnStubs.empty()) {
+ const MCSection *StubSection;
if (TM.getRelocationModel() == Reloc::PIC_)
- SwitchToTextSection(".section __TEXT,__picsymbolstub4,symbol_stubs,"
- "none,16", 0);
+ StubSection = TLOFMacho.getMachOSection(".section __TEXT,__picsymbolstu"
+ "b4,symbol_stubs,none,16", true,
+ SectionKind::getText());
else
- SwitchToTextSection(".section __TEXT,__symbol_stub4,symbol_stubs,"
- "none,12", 0);
-
- EmitAlignment(2);
- O << "\t.code\t32\n";
+ StubSection = TLOFMacho.getMachOSection(".section __TEXT,__symbol_stub4"
+ ",symbol_stubs,none,12", true,
+ SectionKind::getText());
+
+ const MCSection *LazySymbolPointerSection
+ = TLOFMacho.getMachOSection(".lazy_symbol_pointer", true,
+ SectionKind::getMetadata());
+
+ // Output stubs for dynamically-linked functions
+ for (StringMap<FnStubInfo>::iterator I = FnStubs.begin(),
+ E = FnStubs.end(); I != E; ++I) {
+ const FnStubInfo &Info = I->second;
+
+ SwitchToSection(StubSection);
+ EmitAlignment(2);
+ O << "\t.code\t32\n";
- O << Info.Stub << ":\n";
- O << "\t.indirect_symbol " << I->getKeyData() << '\n';
- O << "\tldr ip, " << Info.SLP << '\n';
- if (TM.getRelocationModel() == Reloc::PIC_) {
- O << Info.SCV << ":\n";
- O << "\tadd ip, pc, ip\n";
+ O << Info.Stub << ":\n";
+ O << "\t.indirect_symbol " << I->getKeyData() << '\n';
+ O << "\tldr ip, " << Info.SLP << '\n';
+ if (TM.getRelocationModel() == Reloc::PIC_) {
+ O << Info.SCV << ":\n";
+ O << "\tadd ip, pc, ip\n";
+ }
+ O << "\tldr pc, [ip, #0]\n";
+ O << Info.SLP << ":\n";
+ O << "\t.long\t" << Info.LazyPtr;
+ if (TM.getRelocationModel() == Reloc::PIC_)
+ O << "-(" << Info.SCV << "+8)";
+ O << '\n';
+
+ SwitchToSection(LazySymbolPointerSection);
+ O << Info.LazyPtr << ":\n";
+ O << "\t.indirect_symbol " << I->getKeyData() << "\n";
+ O << "\t.long\tdyld_stub_binding_helper\n";
}
- O << "\tldr pc, [ip, #0]\n";
- O << Info.SLP << ":\n";
- O << "\t.long\t" << Info.LazyPtr;
- if (TM.getRelocationModel() == Reloc::PIC_)
- O << "-(" << Info.SCV << "+8)";
O << '\n';
-
- SwitchToDataSection(".lazy_symbol_pointer", 0);
- O << Info.LazyPtr << ":\n";
- O << "\t.indirect_symbol " << I->getKeyData() << "\n";
- O << "\t.long\tdyld_stub_binding_helper\n";
}
- O << '\n';
-
+
// Output non-lazy-pointers for external and common global variables.
if (!GVNonLazyPtrs.empty()) {
- SwitchToDataSection("\t.non_lazy_symbol_pointer", 0);
- for (StringMap<std::string>::iterator I = GVNonLazyPtrs.begin(),
- E = GVNonLazyPtrs.end(); I != E; ++I) {
+ SwitchToSection(TLOFMacho.getMachOSection(".non_lazy_symbol_pointer",
+ true,
+ SectionKind::getMetadata()));
+ for (StringMap<std::string>::iterator I = GVNonLazyPtrs.begin(),
+ E = GVNonLazyPtrs.end(); I != E; ++I) {
O << I->second << ":\n";
O << "\t.indirect_symbol " << I->getKeyData() << "\n";
O << "\t.long\t0\n";
More information about the llvm-commits
mailing list