aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorKostya Serebryany <kcc@google.com>2011-12-14 00:01:51 +0000
committerKostya Serebryany <kcc@google.com>2011-12-14 00:01:51 +0000
commitbd7910d158ad2e2a3cb17f2b3f160a9c39dd6b0f (patch)
tree5da024bc84d1b977226625ee8cb7f6c34f534d95 /lib
parenta740e19e7e4ef29a7404fac3ac7e513beacf1bf7 (diff)
downloadexternal_llvm-bd7910d158ad2e2a3cb17f2b3f160a9c39dd6b0f.tar.gz
external_llvm-bd7910d158ad2e2a3cb17f2b3f160a9c39dd6b0f.tar.bz2
external_llvm-bd7910d158ad2e2a3cb17f2b3f160a9c39dd6b0f.zip
[asan] remove .preinit_array from the compiler module (it breaks .so builds). This should be done in the run-time.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@146527 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/Transforms/Instrumentation/AddressSanitizer.cpp16
1 files changed, 0 insertions, 16 deletions
diff --git a/lib/Transforms/Instrumentation/AddressSanitizer.cpp b/lib/Transforms/Instrumentation/AddressSanitizer.cpp
index f170cf150a..4d6e74b833 100644
--- a/lib/Transforms/Instrumentation/AddressSanitizer.cpp
+++ b/lib/Transforms/Instrumentation/AddressSanitizer.cpp
@@ -163,8 +163,6 @@ struct AddressSanitizer : public ModulePass {
private:
- void appendToPreinitArray(Module &M, Function *F);
-
uint64_t getAllocaSizeInBytes(AllocaInst *AI) {
Type *Ty = AI->getAllocatedType();
uint64_t SizeInBytes = TD->getTypeStoreSizeInBits(Ty) / 8;
@@ -565,17 +563,6 @@ bool AddressSanitizer::insertGlobalRedzones(Module &M) {
return true;
}
-// .preinit_array is something that hapens before all other inits.
-// On systems where .preinit_array is honored, we will call __asan_init early.
-void AddressSanitizer::appendToPreinitArray(Module &M, Function *F) {
- IRBuilder<> IRB(M.getContext());
- GlobalVariable *Var =
- new GlobalVariable(M, PointerType::getUnqual(F->getFunctionType()),
- false, GlobalValue::PrivateLinkage,
- F, "__asan_preinit_private");
- Var->setSection(".preinit_array");
-}
-
// virtual
bool AddressSanitizer::runOnModule(Module &M) {
// Initialize the private fields. No one has accessed them before.
@@ -647,9 +634,6 @@ bool AddressSanitizer::runOnModule(Module &M) {
appendToGlobalCtors(M, AsanCtorFunction, 1 /*high priority*/);
- if (M.getTargetTriple().find("linux") != std::string::npos)
- appendToPreinitArray(M, AsanInitFunction);
-
return Res;
}