From 4148819f0f3d8a244b1965d88271b813d744374c Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 28 Jun 2003 17:15:12 +0000 Subject: [PATCH] Preserve compatibility with non-gcc compilers git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6932 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/CBackend/CBackend.cpp | 18 ++++++++++++++---- lib/Target/CBackend/Writer.cpp | 18 ++++++++++++++---- 2 files changed, 28 insertions(+), 8 deletions(-) diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp index 739e270f29a..ed4e430a1ca 100644 --- a/lib/Target/CBackend/CBackend.cpp +++ b/lib/Target/CBackend/CBackend.cpp @@ -572,9 +572,13 @@ bool CWriter::nameAllUsedStructureTypes(Module &M) { return Changed; } -static void generateAllocaDecl(std::ostream& Out) { - // On SunOS, we need to insert the alloca macro & proto for the builtin. - Out << "#ifdef sun\n" +// generateCompilerSpecificCode - This is where we add conditional compilation +// directives to cater to specific compilers as need be. +// +static void generateCompilerSpecificCode(std::ostream& Out) { + // Alloca is hard to get, and we don't want to include stdlib.h here... + Out << "/* get a declaration for alloca */\n" + << "#ifdef sun\n" << "extern void *__builtin_alloca(unsigned long);\n" << "#define alloca(x) __builtin_alloca(x)\n" << "#else\n" @@ -582,6 +586,12 @@ static void generateAllocaDecl(std::ostream& Out) { << "#include \n" << "#endif\n" << "#endif\n\n"; + + // We output GCC specific attributes to preserve 'linkonce'ness on globals. + // If we aren't being compiled with GCC, just drop these attributes. + Out << "#ifndef __GNUC__\n" + << "#define __attribute__(X)\n" + << "#endif\n"; } void CWriter::printModule(Module *M) { @@ -606,9 +616,9 @@ void CWriter::printModule(Module *M) { // get declaration for alloca Out << "/* Provide Declarations */\n"; - generateAllocaDecl(Out); Out << "#include \n"; Out << "#include \n"; + generateCompilerSpecificCode(Out); // Provide a definition for `bool' if not compiling with a C++ compiler. Out << "\n" diff --git a/lib/Target/CBackend/Writer.cpp b/lib/Target/CBackend/Writer.cpp index 739e270f29a..ed4e430a1ca 100644 --- a/lib/Target/CBackend/Writer.cpp +++ b/lib/Target/CBackend/Writer.cpp @@ -572,9 +572,13 @@ bool CWriter::nameAllUsedStructureTypes(Module &M) { return Changed; } -static void generateAllocaDecl(std::ostream& Out) { - // On SunOS, we need to insert the alloca macro & proto for the builtin. - Out << "#ifdef sun\n" +// generateCompilerSpecificCode - This is where we add conditional compilation +// directives to cater to specific compilers as need be. +// +static void generateCompilerSpecificCode(std::ostream& Out) { + // Alloca is hard to get, and we don't want to include stdlib.h here... + Out << "/* get a declaration for alloca */\n" + << "#ifdef sun\n" << "extern void *__builtin_alloca(unsigned long);\n" << "#define alloca(x) __builtin_alloca(x)\n" << "#else\n" @@ -582,6 +586,12 @@ static void generateAllocaDecl(std::ostream& Out) { << "#include \n" << "#endif\n" << "#endif\n\n"; + + // We output GCC specific attributes to preserve 'linkonce'ness on globals. + // If we aren't being compiled with GCC, just drop these attributes. + Out << "#ifndef __GNUC__\n" + << "#define __attribute__(X)\n" + << "#endif\n"; } void CWriter::printModule(Module *M) { @@ -606,9 +616,9 @@ void CWriter::printModule(Module *M) { // get declaration for alloca Out << "/* Provide Declarations */\n"; - generateAllocaDecl(Out); Out << "#include \n"; Out << "#include \n"; + generateCompilerSpecificCode(Out); // Provide a definition for `bool' if not compiling with a C++ compiler. Out << "\n"