summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/X86
diff options
context:
space:
mode:
authorJeff Cohen <jeffc@jolt-lang.org>2006-05-02 03:11:50 +0000
committerJeff Cohen <jeffc@jolt-lang.org>2006-05-02 03:11:50 +0000
commitbfe9ffb4490a80c1e1a685b461cdcd19268ef834 (patch)
treeb02e2de5778ba83585886c67164d34eadbf329a3 /llvm/lib/Target/X86
parent24a62a9bc18d5830a701e9b082ff1431965011cb (diff)
downloadbcm5719-llvm-bfe9ffb4490a80c1e1a685b461cdcd19268ef834.tar.gz
bcm5719-llvm-bfe9ffb4490a80c1e1a685b461cdcd19268ef834.zip
Finish support for Microsoft ML/MASM. May still be a few rough edges.
llvm-svn: 28045
Diffstat (limited to 'llvm/lib/Target/X86')
-rwxr-xr-xllvm/lib/Target/X86/X86IntelAsmPrinter.cpp51
-rwxr-xr-xllvm/lib/Target/X86/X86IntelAsmPrinter.h2
2 files changed, 50 insertions, 3 deletions
diff --git a/llvm/lib/Target/X86/X86IntelAsmPrinter.cpp b/llvm/lib/Target/X86/X86IntelAsmPrinter.cpp
index 18295f566c7..112f496eadc 100755
--- a/llvm/lib/Target/X86/X86IntelAsmPrinter.cpp
+++ b/llvm/lib/Target/X86/X86IntelAsmPrinter.cpp
@@ -36,8 +36,6 @@ X86IntelAsmPrinter::X86IntelAsmPrinter(std::ostream &O, X86TargetMachine &TM)
Data32bitsDirective = "\t.dd\t";
Data64bitsDirective = "\t.dq\t";
HasDotTypeDotSizeDirective = false;
-
- O << "\t.686\n\t.model flat\n\toption dotname\n";
}
/// runOnMachineFunction - This uses the printMachineInstruction()
@@ -57,7 +55,7 @@ bool X86IntelAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
EmitConstantPool(MF.getConstantPool());
// Print out labels for the function.
- SwitchSection(".code\n", MF.getFunction());
+ SwitchSection(".code", MF.getFunction());
EmitAlignment(4);
if (MF.getFunction()->getLinkage() == GlobalValue::ExternalLinkage)
O << "\tpublic " << CurrentFnName << "\n";
@@ -424,9 +422,56 @@ void X86IntelAsmPrinter::printMachineInstruction(const MachineInstr *MI) {
bool X86IntelAsmPrinter::doInitialization(Module &M) {
X86SharedAsmPrinter::doInitialization(M);
Mang->markCharUnacceptable('.');
+ PrivateGlobalPrefix = "$"; // need this here too :(
+ O << "\t.686\n\t.model flat\n\n";
+
+ // Emit declarations for external functions.
+ for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I)
+ if (I->isExternal())
+ O << "\textern " << Mang->getValueName(I) << ":near\n";
+
+ // Emit declarations for external globals.
+ for (Module::const_global_iterator I = M.global_begin(), E = M.global_end();
+ I != E; ++I) {
+ if (I->isExternal())
+ O << "\textern " << Mang->getValueName(I) << ":byte\n";
+ }
+
+ return false;
+}
+
+bool X86IntelAsmPrinter::doFinalization(Module &M) {
+ X86SharedAsmPrinter::doFinalization(M);
+ if (CurrentSection != "")
+ O << CurrentSection << "\tends\n";
+ O << "\tend\n";
return false;
}
+void X86IntelAsmPrinter::SwitchSection(const char *NewSection,
+ const GlobalValue *GV) {
+ if (*NewSection == 0)
+ return;
+
+ std::string NS;
+ bool isData = strcmp(NewSection , ".data") == 0;
+
+ if (GV && GV->hasSection())
+ NS = GV->getSection();
+ else if (isData)
+ NS = "_data";
+ else
+ NS = "_text";
+
+ if (CurrentSection != NS) {
+ if (CurrentSection != "")
+ O << CurrentSection << "\tends\n";
+ CurrentSection = NS;
+ O << CurrentSection << (isData ? "\tsegment 'DATA'\n"
+ : "\tsegment 'CODE'\n");
+ }
+}
+
void X86IntelAsmPrinter::EmitZeros(uint64_t NumZeros) const {
if (NumZeros) {
O << "\tdb " << NumZeros << " dup(0)\n";
diff --git a/llvm/lib/Target/X86/X86IntelAsmPrinter.h b/llvm/lib/Target/X86/X86IntelAsmPrinter.h
index c6ad898d1db..7c81923ed66 100755
--- a/llvm/lib/Target/X86/X86IntelAsmPrinter.h
+++ b/llvm/lib/Target/X86/X86IntelAsmPrinter.h
@@ -90,7 +90,9 @@ struct X86IntelAsmPrinter : public X86SharedAsmPrinter {
void printPICLabel(const MachineInstr *MI, unsigned Op);
bool runOnMachineFunction(MachineFunction &F);
bool doInitialization(Module &M);
+ bool doFinalization(Module &M);
+ virtual void SwitchSection(const char *NewSection, const GlobalValue *GV);
virtual void EmitZeros(uint64_t NumZeros) const;
virtual void EmitString(const ConstantArray *CVA) const;
};
OpenPOWER on IntegriCloud