Respect verify-llvm-ir option in the backend
We are currently unconditionally verifying the LLVM IR in the backend (twice), ignoring the value of the verify-llvm-ir option.
This commit is contained in:
parent
f2abf827c1
commit
d3ad000943
3 changed files with 8 additions and 3 deletions
|
@ -552,7 +552,7 @@ static CodeGenFileType fromRust(LLVMRustFileType Type) {
|
|||
extern "C" LLVMRustResult
|
||||
LLVMRustWriteOutputFile(LLVMTargetMachineRef Target, LLVMPassManagerRef PMR,
|
||||
LLVMModuleRef M, const char *Path, const char *DwoPath,
|
||||
LLVMRustFileType RustFileType) {
|
||||
LLVMRustFileType RustFileType, bool VerifyIR) {
|
||||
llvm::legacy::PassManager *PM = unwrap<llvm::legacy::PassManager>(PMR);
|
||||
auto FileType = fromRust(RustFileType);
|
||||
|
||||
|
@ -577,10 +577,10 @@ LLVMRustWriteOutputFile(LLVMTargetMachineRef Target, LLVMPassManagerRef PMR,
|
|||
return LLVMRustResult::Failure;
|
||||
}
|
||||
auto DBOS = buffer_ostream(DOS);
|
||||
unwrap(Target)->addPassesToEmitFile(*PM, BOS, &DBOS, FileType, false);
|
||||
unwrap(Target)->addPassesToEmitFile(*PM, BOS, &DBOS, FileType, !VerifyIR);
|
||||
PM->run(*unwrap(M));
|
||||
} else {
|
||||
unwrap(Target)->addPassesToEmitFile(*PM, BOS, nullptr, FileType, false);
|
||||
unwrap(Target)->addPassesToEmitFile(*PM, BOS, nullptr, FileType, !VerifyIR);
|
||||
PM->run(*unwrap(M));
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue