summaryrefslogtreecommitdiff
path: root/lib/Target/CBackend/CBackend.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-05-06 06:58:42 +0000
committerChris Lattner <sabre@nondot.org>2005-05-06 06:58:42 +0000
commit50a8a17e6525b75e8f307eb4fd39e223a83bbc03 (patch)
tree33132982b23816456cd50da93f224e87e3e3cf7f /lib/Target/CBackend/CBackend.cpp
parentfe673d93511fef5aa4b1e275d00ea71ea4e94604 (diff)
downloadllvm-50a8a17e6525b75e8f307eb4fd39e223a83bbc03.tar.gz
llvm-50a8a17e6525b75e8f307eb4fd39e223a83bbc03.tar.bz2
llvm-50a8a17e6525b75e8f307eb4fd39e223a83bbc03.tar.xz
clean up the CBE output a bit
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21740 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/CBackend/CBackend.cpp')
-rw-r--r--lib/Target/CBackend/CBackend.cpp28
1 files changed, 15 insertions, 13 deletions
diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp
index be124b0501..282d013047 100644
--- a/lib/Target/CBackend/CBackend.cpp
+++ b/lib/Target/CBackend/CBackend.cpp
@@ -215,7 +215,6 @@ namespace {
unsigned Indent);
void printIndexingExpression(Value *Ptr, gep_type_iterator I,
gep_type_iterator E);
- void printCodeForMain();
};
}
@@ -815,8 +814,20 @@ static void generateCompilerSpecificCode(std::ostream& Out) {
<< "#define LLVM_NANSF(NanStr) 0.0F /* Float */\n"
<< "#define LLVM_INF ((double)0.0) /* Double */\n"
<< "#define LLVM_INFF 0.0F /* Float */\n"
- << "#define LLVM_PREFETCH(addr,rw,locality) \n"
- << "#endif\n";
+ << "#define LLVM_PREFETCH(addr,rw,locality) /* PREFETCH */\n"
+ << "#endif\n\n";
+
+ // Output target-specific code that should be inserted into main.
+ Out << "#define CODE_FOR_MAIN() /* Any target-specific code for main()*/\n";
+ // On X86, set the FP control word to 64-bits of precision instead of 80 bits.
+ Out << "#if defined(__GNUC__) && !defined(__llvm__)\n"
+ << "#if defined(i386) || defined(__i386__) || defined(__i386)\n"
+ << "#undef CODE_FOR_MAIN\n"
+ << "#define CODE_FOR_MAIN() \\\n"
+ << " {short F;__asm__ (\"fnstcw %0\" : \"=m\" (*&F)); \\\n"
+ << " F=(F&~0x300)|0x200;__asm__(\"fldcw %0\"::\"m\"(*&F));}\n"
+ << "#endif\n#endif\n";
+
}
bool CWriter::doInitialization(Module &M) {
@@ -1140,7 +1151,7 @@ void CWriter::printFunction(Function &F) {
Out << '\n';
if (F.hasExternalLinkage() && F.getName() == "main")
- printCodeForMain();
+ Out << " CODE_FOR_MAIN();\n";
// print the basic blocks
for (Function::iterator BB = F.begin(), E = F.end(); BB != E; ++BB) {
@@ -1155,15 +1166,6 @@ void CWriter::printFunction(Function &F) {
Out << "}\n\n";
}
-void CWriter::printCodeForMain() {
- // On X86, set the FP control word to 64-bits of precision instead of 80 bits.
- Out << "#if defined(__GNUC__) && !defined(__llvm__)\n"
- << "#if defined(i386) || defined(__i386__) || defined(__i386)\n"
- << "{short FPCW;__asm__ (\"fnstcw %0\" : \"=m\" (*&FPCW));\n"
- << "FPCW=(FPCW&~0x300)|0x200;__asm__(\"fldcw %0\" :: \"m\" (*&FPCW));}\n"
- << "#endif\n#endif\n";
-}
-
void CWriter::printLoop(Loop *L) {
Out << " do { /* Syntactic loop '" << L->getHeader()->getName()
<< "' to make GCC happy */\n";