summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-11-21 22:19:48 +0000
committerChris Lattner <sabre@nondot.org>2005-11-21 22:19:48 +0000
commitebc39f5a9c2824e648c1a84e7946b230fd74cb09 (patch)
treeefc281a9409af18a5047845b6672de85f604831d /llvm/lib
parent505ee2b886f56024b20f4075c7e24c695e9efbe2 (diff)
downloadbcm5719-llvm-ebc39f5a9c2824e648c1a84e7946b230fd74cb09.tar.gz
bcm5719-llvm-ebc39f5a9c2824e648c1a84e7946b230fd74cb09.zip
Add a forELF flag, allowing the removal of forCygwin and simplification of
conditionals. llvm-svn: 24475
Diffstat (limited to 'llvm/lib')
-rwxr-xr-xllvm/lib/Target/X86/X86ATTAsmPrinter.cpp2
-rw-r--r--llvm/lib/Target/X86/X86AsmPrinter.cpp11
-rwxr-xr-xllvm/lib/Target/X86/X86AsmPrinter.h4
-rwxr-xr-xllvm/lib/Target/X86/X86IntelAsmPrinter.cpp2
4 files changed, 12 insertions, 7 deletions
diff --git a/llvm/lib/Target/X86/X86ATTAsmPrinter.cpp b/llvm/lib/Target/X86/X86ATTAsmPrinter.cpp
index 3a1ac86576f..7420012d70c 100755
--- a/llvm/lib/Target/X86/X86ATTAsmPrinter.cpp
+++ b/llvm/lib/Target/X86/X86ATTAsmPrinter.cpp
@@ -35,7 +35,7 @@ bool X86ATTAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
SwitchSection("\t.text\n", MF.getFunction());
EmitAlignment(4); // FIXME: This should be parameterized somewhere.
O << "\t.globl\t" << CurrentFnName << "\n";
- if (!forCygwin && !forDarwin)
+ if (forELF)
O << "\t.type\t" << CurrentFnName << ", @function\n";
O << CurrentFnName << ":\n";
diff --git a/llvm/lib/Target/X86/X86AsmPrinter.cpp b/llvm/lib/Target/X86/X86AsmPrinter.cpp
index 36f4249e223..5b9742bd440 100644
--- a/llvm/lib/Target/X86/X86AsmPrinter.cpp
+++ b/llvm/lib/Target/X86/X86AsmPrinter.cpp
@@ -39,15 +39,18 @@ AsmWriterFlavor("x86-asm-syntax",
cl::init(att));
/// doInitialization
-bool X86SharedAsmPrinter::doInitialization(Module& M) {
- forCygwin = false;
+bool X86SharedAsmPrinter::doInitialization(Module &M) {
+ bool forCygwin = false;
forDarwin = false;
+ forELF = false;
bool forWin32 = false;
const std::string& TT = M.getTargetTriple();
if (TT.length() > 5) {
forCygwin = TT.find("cygwin") != std::string::npos ||
TT.find("mingw") != std::string::npos;
forDarwin = TT.find("darwin") != std::string::npos;
+ if (!forDarwin && !forCygwin)
+ forELF = true;
} else if (TT.empty()) {
#if defined(__CYGWIN__) || defined(__MINGW32__)
forCygwin = true;
@@ -55,6 +58,8 @@ bool X86SharedAsmPrinter::doInitialization(Module& M) {
forDarwin = true;
#elif defined(_WIN32)
forWin32 = true;
+#else
+ forELF = true;
#endif
}
@@ -139,7 +144,7 @@ bool X86SharedAsmPrinter::doFinalization(Module &M) {
}
EmitAlignment(Align);
- if (!forCygwin && !forDarwin) {
+ if (forELF) {
O << "\t.type " << name << ",@object\n";
O << "\t.size " << name << "," << Size << "\n";
}
diff --git a/llvm/lib/Target/X86/X86AsmPrinter.h b/llvm/lib/Target/X86/X86AsmPrinter.h
index 61dd2f295e7..649ec4d0247 100755
--- a/llvm/lib/Target/X86/X86AsmPrinter.h
+++ b/llvm/lib/Target/X86/X86AsmPrinter.h
@@ -29,12 +29,12 @@ extern Statistic<> EmittedInsts;
struct X86SharedAsmPrinter : public AsmPrinter {
X86SharedAsmPrinter(std::ostream &O, TargetMachine &TM)
- : AsmPrinter(O, TM), forCygwin(false), forDarwin(false) { }
+ : AsmPrinter(O, TM), forELF(false), forDarwin(false) { }
bool doInitialization(Module &M);
bool doFinalization(Module &M);
- bool forCygwin;
+ bool forELF;
bool forDarwin;
// Necessary for Darwin to print out the apprioriate types of linker stubs
diff --git a/llvm/lib/Target/X86/X86IntelAsmPrinter.cpp b/llvm/lib/Target/X86/X86IntelAsmPrinter.cpp
index 1c9f803a0e1..f4464b3e437 100755
--- a/llvm/lib/Target/X86/X86IntelAsmPrinter.cpp
+++ b/llvm/lib/Target/X86/X86IntelAsmPrinter.cpp
@@ -35,7 +35,7 @@ bool X86IntelAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
SwitchSection("\t.text\n", MF.getFunction());
EmitAlignment(4);
O << "\t.globl\t" << CurrentFnName << "\n";
- if (!forCygwin && !forDarwin)
+ if (forELF)
O << "\t.type\t" << CurrentFnName << ", @function\n";
O << CurrentFnName << ":\n";
OpenPOWER on IntegriCloud