From 22d26d7c7d7c9666d0da0e51250586da5a0744da Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 20 Feb 2002 17:56:53 +0000 Subject: [PATCH] * Expose the verifier pass as one that can be ran * Force the verifier to run before bytecode is written git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1783 91177308-0d34-0410-b5e6-96231b3b80d8 --- tools/opt/opt.cpp | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/tools/opt/opt.cpp b/tools/opt/opt.cpp index 13a07748af8..2d77306671e 100644 --- a/tools/opt/opt.cpp +++ b/tools/opt/opt.cpp @@ -11,6 +11,7 @@ #include "llvm/Bytecode/Reader.h" #include "llvm/Bytecode/WriteBytecodePass.h" #include "llvm/Assembly/PrintModulePass.h" +#include "llvm/Analysis/Verifier.h" #include "llvm/Transforms/UnifyMethodExitNodes.h" #include "llvm/Transforms/ConstantMerge.h" #include "llvm/Transforms/CleanupGCCOutput.h" @@ -36,7 +37,10 @@ enum Opts { dce, constprop, inlining, constmerge, strip, mstrip, mergereturn, // Miscellaneous Transformations - trace, tracem, print, raiseallocs, cleangcc, + trace, tracem, raiseallocs, cleangcc, + + // Printing and verifying... + print, verify, // More powerful optimizations indvars, instcombine, sccp, adce, raise, mem2reg, @@ -93,6 +97,7 @@ struct { { trace , New }, { tracem , New }, { print , NewPrintMethodPass }, + { verify , createVerifierPass }, { raiseallocs, New }, { cleangcc , New }, { globaldce , New }, @@ -134,7 +139,9 @@ cl::EnumList OptimizationList(cl::NoFlags, clEnumVal(raise , "Raise to Higher Level"), clEnumVal(trace , "Insert BB & Method trace code"), clEnumVal(tracem , "Insert Method trace code only"), + clEnumVal(print , "Print working method to stderr"), + clEnumVal(verify , "Verify module is well formed"), 0); @@ -185,6 +192,9 @@ int main(int argc, char **argv) { Passes.add(new PrintModulePass(&std::cerr)); } + // Check that the module is well formed on completion of optimization + Passes.add(createVerifierPass()); + // Write bytecode out to disk or cout as the last step... Passes.add(new WriteBytecodePass(Out, Out != &std::cout));