diff options
author | Craig Topper <craig.topper@gmail.com> | 2017-01-13 06:26:18 +0000 |
---|---|---|
committer | Craig Topper <craig.topper@gmail.com> | 2017-01-13 06:26:18 +0000 |
commit | eec489034699f45f6ff236e74b27989a0d0d507f (patch) | |
tree | 7717ce1f07c679af69f8ba198d195741e787653d | |
parent | d409411ef195329a24cea00589e9853ab6a5ace8 (diff) | |
download | bcm5719-llvm-eec489034699f45f6ff236e74b27989a0d0d507f.tar.gz bcm5719-llvm-eec489034699f45f6ff236e74b27989a0d0d507f.zip |
[IR] Don't call assertModuleIsMaterialized in release builds
Summary:
To fix a release vs debug build linking error, r259695 made the body of assertModuleIsMaterialized empty if Value.cpp gets compiled in a release build. This way any code compiled as a debug build can still link against a release version of the function.
This patch takes this a step farther and removes all calls to it from Value.h in any code that includes it in a relase build.
This shrinks the opt binary on my macbook build by 17240 bytes.
Reviewers: rafael
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D28191
llvm-svn: 291883
-rw-r--r-- | llvm/include/llvm/IR/Value.h | 10 | ||||
-rw-r--r-- | llvm/lib/IR/Value.cpp | 2 |
2 files changed, 10 insertions, 2 deletions
diff --git a/llvm/include/llvm/IR/Value.h b/llvm/include/llvm/IR/Value.h index bdafbbf58cc..9c91f4e07e3 100644 --- a/llvm/include/llvm/IR/Value.h +++ b/llvm/include/llvm/IR/Value.h @@ -294,7 +294,15 @@ public: // when using them since you might not get all uses. // The methods that don't start with materialized_ assert that modules is // fully materialized. - void assertModuleIsMaterialized() const; + void assertModuleIsMaterializedImpl() const; + // This indirection exists so we can keep assertModuleIsMaterializedImpl() + // around in release builds of Value.cpp to be linked with other code built + // in debug mode. But this avoids calling it in any of the release built code. + void assertModuleIsMaterialized() const { +#ifndef NDEBUG + assertModuleIsMaterializedImpl(); +#endif + } bool use_empty() const { assertModuleIsMaterialized(); diff --git a/llvm/lib/IR/Value.cpp b/llvm/lib/IR/Value.cpp index 91a999b5800..d86d7fc1164 100644 --- a/llvm/lib/IR/Value.cpp +++ b/llvm/lib/IR/Value.cpp @@ -320,7 +320,7 @@ void Value::takeName(Value *V) { ST->reinsertValue(this); } -void Value::assertModuleIsMaterialized() const { +void Value::assertModuleIsMaterializedImpl() const { #ifndef NDEBUG const GlobalValue *GV = dyn_cast<GlobalValue>(this); if (!GV) |