mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-01 02:33:44 +00:00
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
This commit is contained in:
parent
3e5d1d8d08
commit
8383a7b7a6
@ -103,6 +103,7 @@ namespace {
|
|||||||
(void) llvm::createStripDeadPrototypesPass();
|
(void) llvm::createStripDeadPrototypesPass();
|
||||||
(void) llvm::createTailCallEliminationPass();
|
(void) llvm::createTailCallEliminationPass();
|
||||||
(void) llvm::createTailDuplicationPass();
|
(void) llvm::createTailDuplicationPass();
|
||||||
|
(void) llvm::createJumpThreadingPass();
|
||||||
(void) llvm::createUnifyFunctionExitNodesPass();
|
(void) llvm::createUnifyFunctionExitNodesPass();
|
||||||
(void) llvm::createCondPropagationPass();
|
(void) llvm::createCondPropagationPass();
|
||||||
(void) llvm::createNullProfilerRSPass();
|
(void) llvm::createNullProfilerRSPass();
|
||||||
|
@ -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,
|
// CFGSimplification - Merge basic blocks, eliminate unreachable blocks,
|
||||||
// simplify terminator instructions, etc...
|
// simplify terminator instructions, etc...
|
||||||
//
|
//
|
||||||
|
52
lib/Transforms/Scalar/JumpThreading.cpp
Normal file
52
lib/Transforms/Scalar/JumpThreading.cpp
Normal file
@ -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<unsigned>
|
||||||
|
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<JumpThreading> 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;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user