summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-03-21 23:38:23 +0000
committerDan Gohman <gohman@apple.com>2008-03-21 23:38:23 +0000
commit5a6ac79738406a4902908cd53735b84f8cddfa2f (patch)
tree5a333e00467f60be18fca4e4e3c722b1a025dae0
parent30e44a4b403f442396f33f6af0fcc3b39526f9a8 (diff)
downloadbcm5719-llvm-5a6ac79738406a4902908cd53735b84f8cddfa2f.tar.gz
bcm5719-llvm-5a6ac79738406a4902908cd53735b84f8cddfa2f.zip
Specialize FORCE_DEFINING_FILE_TO_BE_LINKED using a GCC trick
to avoid using constructor calls for static objects. This reduces the number of objects requiring static constructors in a typical LLVM build by around 20%. llvm-svn: 48665
-rw-r--r--llvm/include/llvm/System/IncludeFile.h21
-rw-r--r--llvm/lib/System/IncludeFile.cpp2
2 files changed, 18 insertions, 5 deletions
diff --git a/llvm/include/llvm/System/IncludeFile.h b/llvm/include/llvm/System/IncludeFile.h
index 7617373ad19..6103e44e4cf 100644
--- a/llvm/include/llvm/System/IncludeFile.h
+++ b/llvm/include/llvm/System/IncludeFile.h
@@ -26,16 +26,29 @@
///
/// And, foo.cp would use:<br/>
/// <tt>DEFINING_FILE_FOR(foo)</tt><br/>
+#ifdef __GNUC__
+// If the `used' attribute is available, use it to create a variable
+// with an initializer that will force the linking of the defining file.
#define FORCE_DEFINING_FILE_TO_BE_LINKED(name) \
namespace llvm { \
- extern char name ## LinkVar; \
- static IncludeFile name ## LinkObj ( &name ## LinkVar ); \
+ extern const char name ## LinkVar; \
+ __attribute__((used)) static const char *const name ## LinkObj = \
+ &name ## LinkVar; \
}
+#else
+// Otherwise use a constructor call.
+#define FORCE_DEFINING_FILE_TO_BE_LINKED(name) \
+ namespace llvm { \
+ extern const char name ## LinkVar; \
+ static const IncludeFile name ## LinkObj ( &name ## LinkVar ); \
+ }
+#endif
/// This macro is the counterpart to FORCE_DEFINING_FILE_TO_BE_LINKED. It should
/// be used in a .cpp file to define the name referenced in a header file that
/// will cause linkage of the .cpp file. It should only be used at extern level.
-#define DEFINING_FILE_FOR(name) namespace llvm { char name ## LinkVar; }
+#define DEFINING_FILE_FOR(name) \
+ namespace llvm { const char name ## LinkVar = 0; }
namespace llvm {
@@ -57,7 +70,7 @@ namespace llvm {
/// <tt>static IncludeFile LinkMyModule(&LinkMyCodeStub);</tt><br/>
/// @brief Class to ensure linking of corresponding object file.
struct IncludeFile {
- IncludeFile(void *);
+ explicit IncludeFile(const void *);
};
}
diff --git a/llvm/lib/System/IncludeFile.cpp b/llvm/lib/System/IncludeFile.cpp
index d927e159591..8258d40326f 100644
--- a/llvm/lib/System/IncludeFile.cpp
+++ b/llvm/lib/System/IncludeFile.cpp
@@ -17,4 +17,4 @@ using namespace llvm;
// This constructor is used to ensure linking of other modules. See the
// llvm/System/IncludeFile.h header for details.
-IncludeFile::IncludeFile(void*) {}
+IncludeFile::IncludeFile(const void*) {}
OpenPOWER on IntegriCloud