From 8383a7b7a6acdae478d4b4c2520915153b73f676 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 20 Apr 2008 20:35:01 +0000 Subject: [PATCH] Add a new Jump Threading pass, which will handle cases such as those in PR2235. Right now the pass is not very effective. :) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@50000 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/LinkAllPasses.h | 1 + include/llvm/Transforms/Scalar.h | 7 ++++ lib/Transforms/Scalar/JumpThreading.cpp | 52 +++++++++++++++++++++++++ 3 files changed, 60 insertions(+) create mode 100644 lib/Transforms/Scalar/JumpThreading.cpp diff --git a/include/llvm/LinkAllPasses.h b/include/llvm/LinkAllPasses.h index 360f9dff94a..c13b1e63bc2 100644 --- a/include/llvm/LinkAllPasses.h +++ b/include/llvm/LinkAllPasses.h @@ -103,6 +103,7 @@ namespace { (void) llvm::createStripDeadPrototypesPass(); (void) llvm::createTailCallEliminationPass(); (void) llvm::createTailDuplicationPass(); + (void) llvm::createJumpThreadingPass(); (void) llvm::createUnifyFunctionExitNodesPass(); (void) llvm::createCondPropagationPass(); (void) llvm::createNullProfilerRSPass(); diff --git a/include/llvm/Transforms/Scalar.h b/include/llvm/Transforms/Scalar.h index c7e87239c4f..bcb791617b2 100644 --- a/include/llvm/Transforms/Scalar.h +++ b/include/llvm/Transforms/Scalar.h @@ -199,6 +199,13 @@ FunctionPass *createTailDuplicationPass(); //===----------------------------------------------------------------------===// // +// JumpThreading - Thread control through mult-pred/multi-succ blocks where some +// preds always go to some succ. +// +FunctionPass *createJumpThreadingPass(); + + //===----------------------------------------------------------------------===// +// // CFGSimplification - Merge basic blocks, eliminate unreachable blocks, // simplify terminator instructions, etc... // diff --git a/lib/Transforms/Scalar/JumpThreading.cpp b/lib/Transforms/Scalar/JumpThreading.cpp new file mode 100644 index 00000000000..7773edb7e7e --- /dev/null +++ b/lib/Transforms/Scalar/JumpThreading.cpp @@ -0,0 +1,52 @@ +//===- JumpThreading.cpp - Thread control through conditional blocks ------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This pass performs 'jump threading', which looks at blocks that have multiple +// predecessors and multiple successors. If one or more of the predecessors of +// the block can be proven to always jump to one of the successors, we forward +// the edge from the predecessor to the successor by duplicating the contents of +// this block. +// +//===----------------------------------------------------------------------===// + +#define DEBUG_TYPE "jump-threading" +#include "llvm/Transforms/Scalar.h" +#include "llvm/Pass.h" +#include "llvm/ADT/Statistic.h" +#include "llvm/Support/CommandLine.h" +#include "llvm/Support/Compiler.h" +using namespace llvm; + +//STATISTIC(NumThreads, "Number of jumps threaded"); + +namespace { + cl::opt + Threshold("jump-threading-threshold", + cl::desc("Max block size to duplicate for jump threading"), + cl::init(6), cl::Hidden); + class VISIBILITY_HIDDEN JumpThreading : public FunctionPass { + public: + static char ID; // Pass identification + JumpThreading() : FunctionPass((intptr_t)&ID) {} + + bool runOnFunction(Function &F); + }; + char JumpThreading::ID = 0; + RegisterPass X("jump-threading", "Jump Threading"); +} + +// Public interface to the Jump Threading pass +FunctionPass *llvm::createJumpThreadingPass() { return new JumpThreading(); } + +/// runOnFunction - Top level algorithm. +/// +bool JumpThreading::runOnFunction(Function &F) { + bool Changed = false; + return Changed; +}