mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 11:42:57 +01:00
18e8c62883
LLVM's include tree and the use of using declarations to hide the 'legacy' namespace for the old pass manager. This undoes the primary modules-hostile change I made to keep out-of-tree targets building. I sent an email inquiring about whether this would be reasonable to do at this phase and people seemed fine with it, so making it a reality. This should allow us to start bootstrapping with modules to a certain extent along with making it easier to mix and match headers in general. The updates to any code for users of LLVM are very mechanical. Switch from including "llvm/PassManager.h" to "llvm/IR/LegacyPassManager.h". Qualify the types which now produce compile errors with "legacy::". The most common ones are "PassManager", "PassManagerBase", and "FunctionPassManager". llvm-svn: 229094
47 lines
1.5 KiB
C++
47 lines
1.5 KiB
C++
//===- InstrumentationBindings.cpp - instrumentation bindings -------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines C bindings for the instrumentation component.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "InstrumentationBindings.h"
|
|
#include "llvm-c/Core.h"
|
|
#include "llvm/IR/LegacyPassManager.h"
|
|
#include "llvm/IR/Module.h"
|
|
#include "llvm/Transforms/Instrumentation.h"
|
|
|
|
using namespace llvm;
|
|
|
|
void LLVMAddAddressSanitizerFunctionPass(LLVMPassManagerRef PM) {
|
|
unwrap(PM)->add(createAddressSanitizerFunctionPass());
|
|
}
|
|
|
|
void LLVMAddAddressSanitizerModulePass(LLVMPassManagerRef PM) {
|
|
unwrap(PM)->add(createAddressSanitizerModulePass());
|
|
}
|
|
|
|
void LLVMAddThreadSanitizerPass(LLVMPassManagerRef PM) {
|
|
unwrap(PM)->add(createThreadSanitizerPass());
|
|
}
|
|
|
|
void LLVMAddMemorySanitizerPass(LLVMPassManagerRef PM) {
|
|
unwrap(PM)->add(createMemorySanitizerPass());
|
|
}
|
|
|
|
void LLVMAddDataFlowSanitizerPass(LLVMPassManagerRef PM,
|
|
int ABIListFilesNum,
|
|
const char **ABIListFiles) {
|
|
std::vector<std::string> ABIListFilesVec;
|
|
for (int i = 0; i != ABIListFilesNum; ++i) {
|
|
ABIListFilesVec.push_back(ABIListFiles[i]);
|
|
}
|
|
unwrap(PM)->add(createDataFlowSanitizerPass(ABIListFilesVec));
|
|
}
|