mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-21 16:31:16 +00:00
mc'ize elf stub printing, convert cygwin stuff to EmitRawText,
which will abort in .o file writing mode. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100314 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c75c028a15
commit
c82d9c4e5c
@ -577,10 +577,11 @@ void X86AsmPrinter::EmitEndOfAsmFile(Module &M) {
|
||||
// Emit type information for external functions
|
||||
for (X86COFFMachineModuleInfo::stub_iterator I = COFFMMI.stub_begin(),
|
||||
E = COFFMMI.stub_end(); I != E; ++I) {
|
||||
O << "\t.def\t " << I->getKeyData()
|
||||
<< ";\t.scl\t" << COFF::C_EXT
|
||||
<< ";\t.type\t" << (COFF::DT_FCN << COFF::N_BTSHFT)
|
||||
<< ";\t.endef\n";
|
||||
OutStreamer.EmitRawText("\t.def\t " + Twine(I->getKeyData()) +
|
||||
";\t.scl\t" + Twine(COFF::C_EXT) +
|
||||
";\t.type\t" +
|
||||
Twine(COFF::DT_FCN << COFF::N_BTSHFT) +
|
||||
";\t.endef");
|
||||
}
|
||||
|
||||
if (Subtarget->isTargetCygMing()) {
|
||||
@ -605,10 +606,13 @@ void X86AsmPrinter::EmitEndOfAsmFile(Module &M) {
|
||||
true,
|
||||
SectionKind::getMetadata()));
|
||||
for (unsigned i = 0, e = DLLExportedGlobals.size(); i != e; ++i)
|
||||
O << "\t.ascii \" -export:" << *DLLExportedGlobals[i] << ",data\"\n";
|
||||
OutStreamer.EmitRawText("\t.ascii \" -export:" +
|
||||
Twine(DLLExportedGlobals[i]->getName()) +
|
||||
",data\"");
|
||||
|
||||
for (unsigned i = 0, e = DLLExportedFns.size(); i != e; ++i)
|
||||
O << "\t.ascii \" -export:" << *DLLExportedFns[i] << "\"\n";
|
||||
OutStreamer.EmitRawText("\t.ascii \" -export:" +
|
||||
Twine(DLLExportedFns[i]->getName()) + "\"");
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -625,12 +629,11 @@ void X86AsmPrinter::EmitEndOfAsmFile(Module &M) {
|
||||
OutStreamer.SwitchSection(TLOFELF.getDataRelSection());
|
||||
const TargetData *TD = TM.getTargetData();
|
||||
|
||||
for (unsigned i = 0, e = Stubs.size(); i != e; ++i)
|
||||
O << *Stubs[i].first << ":\n"
|
||||
<< (TD->getPointerSize() == 8 ?
|
||||
MAI->getData64bitsDirective() : MAI->getData32bitsDirective())
|
||||
<< *Stubs[i].second.getPointer() << '\n';
|
||||
|
||||
for (unsigned i = 0, e = Stubs.size(); i != e; ++i) {
|
||||
OutStreamer.EmitLabel(Stubs[i].first);
|
||||
OutStreamer.EmitSymbolValue(Stubs[i].second.getPointer(),
|
||||
TD->getPointerSize(), 0);
|
||||
}
|
||||
Stubs.clear();
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user