diff options
author | Anton Korobeynikov <asl@math.spbu.ru> | 2007-01-12 19:20:47 +0000 |
---|---|---|
committer | Anton Korobeynikov <asl@math.spbu.ru> | 2007-01-12 19:20:47 +0000 |
commit | a0554d90e87f339b6c0d7482a3e47f4a85c588be (patch) | |
tree | 4e989acdda62e6f10c329ed2669c557c15ffb09b /llvm/lib/Target/CBackend/CBackend.cpp | |
parent | e759955c668b72ec15b5e35bdb07bb5b00e65172 (diff) | |
download | bcm5719-llvm-a0554d90e87f339b6c0d7482a3e47f4a85c588be.tar.gz bcm5719-llvm-a0554d90e87f339b6c0d7482a3e47f4a85c588be.zip |
* PIC codegen for X86/Linux has been implemented
* PIC-aware internal structures in X86 Codegen have been refactored
* Visibility (default/weak) has been added
* Docs fixes (external weak linkage, visibility, formatting)
llvm-svn: 33136
Diffstat (limited to 'llvm/lib/Target/CBackend/CBackend.cpp')
-rw-r--r-- | llvm/lib/Target/CBackend/CBackend.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/Target/CBackend/CBackend.cpp b/llvm/lib/Target/CBackend/CBackend.cpp index a0b4ceb7f19..1346acbb040 100644 --- a/llvm/lib/Target/CBackend/CBackend.cpp +++ b/llvm/lib/Target/CBackend/CBackend.cpp @@ -1290,6 +1290,11 @@ static void generateCompilerSpecificCode(std::ostream& Out) { << "#define __ATTRIBUTE_WEAK__\n" << "#endif\n\n"; + // Add hidden visibility support. FIXME: APPLE_CC? + Out << "#if defined(__GNUC__)\n" + << "#define __HIDDEN__ __attribute__((visibility(\"hidden\")))\n" + << "#endif\n\n"; + // Define NaN and Inf as GCC builtins if using GCC, as 0 otherwise // From the GCC documentation: // @@ -1500,6 +1505,8 @@ bool CWriter::doInitialization(Module &M) { Out << " __ATTRIBUTE_CTOR__"; if (StaticDtors.count(I)) Out << " __ATTRIBUTE_DTOR__"; + if (I->hasHiddenVisibility()) + Out << " __HIDDEN__"; if (I->hasName() && I->getName()[0] == 1) Out << " LLVM_ASM(\"" << I->getName().c_str()+1 << "\")"; @@ -1531,6 +1538,8 @@ bool CWriter::doInitialization(Module &M) { Out << " __ATTRIBUTE_WEAK__"; else if (I->hasExternalWeakLinkage()) Out << " __EXTERNAL_WEAK__"; + if (I->hasHiddenVisibility()) + Out << " __HIDDEN__"; Out << ";\n"; } } @@ -1559,6 +1568,9 @@ bool CWriter::doInitialization(Module &M) { else if (I->hasWeakLinkage()) Out << " __ATTRIBUTE_WEAK__"; + if (I->hasHiddenVisibility()) + Out << " __HIDDEN__"; + // If the initializer is not null, emit the initializer. If it is null, // we try to avoid emitting large amounts of zeros. The problem with // this, however, occurs when the variable has weak linkage. In this |