Misha Brukman | 82c89b9 | 2003-05-20 21:01:22 +0000 | [diff] [blame] | 1 | //===- ConstantProp.cpp - Code to perform Simple Constant Propagation -----===// |
Misha Brukman | fd93908 | 2005-04-21 23:48:37 +0000 | [diff] [blame] | 2 | // |
John Criswell | b576c94 | 2003-10-20 19:43:21 +0000 | [diff] [blame] | 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
Chris Lattner | 4ee451d | 2007-12-29 20:36:04 +0000 | [diff] [blame] | 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
Misha Brukman | fd93908 | 2005-04-21 23:48:37 +0000 | [diff] [blame] | 7 | // |
John Criswell | b576c94 | 2003-10-20 19:43:21 +0000 | [diff] [blame] | 8 | //===----------------------------------------------------------------------===// |
Chris Lattner | 0095054 | 2001-06-06 20:29:01 +0000 | [diff] [blame] | 9 | // |
Misha Brukman | 82c89b9 | 2003-05-20 21:01:22 +0000 | [diff] [blame] | 10 | // This file implements constant propagation and merging: |
Chris Lattner | 0095054 | 2001-06-06 20:29:01 +0000 | [diff] [blame] | 11 | // |
| 12 | // Specifically, this: |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 13 | // * Converts instructions like "add int 1, 2" into 3 |
Chris Lattner | 0095054 | 2001-06-06 20:29:01 +0000 | [diff] [blame] | 14 | // |
| 15 | // Notice that: |
| 16 | // * This pass has a habit of making definitions be dead. It is a good idea |
Duncan Sands | 58921fe | 2008-08-01 12:23:49 +0000 | [diff] [blame] | 17 | // to run a DIE pass sometime after running this pass. |
Chris Lattner | 0095054 | 2001-06-06 20:29:01 +0000 | [diff] [blame] | 18 | // |
| 19 | //===----------------------------------------------------------------------===// |
| 20 | |
Chris Lattner | 0e5f499 | 2006-12-19 21:40:18 +0000 | [diff] [blame] | 21 | #define DEBUG_TYPE "constprop" |
Chris Lattner | 022103b | 2002-05-07 20:03:00 +0000 | [diff] [blame] | 22 | #include "llvm/Transforms/Scalar.h" |
Chandler Carruth | d04a8d4 | 2012-12-03 16:50:05 +0000 | [diff] [blame] | 23 | #include "llvm/ADT/Statistic.h" |
Chris Lattner | 79066fa | 2007-01-30 23:46:24 +0000 | [diff] [blame] | 24 | #include "llvm/Analysis/ConstantFolding.h" |
Chandler Carruth | 0b8c9a8 | 2013-01-02 11:36:10 +0000 | [diff] [blame^] | 25 | #include "llvm/IR/Constant.h" |
| 26 | #include "llvm/IR/DataLayout.h" |
| 27 | #include "llvm/IR/Instruction.h" |
Chris Lattner | bd0ef77 | 2002-02-26 21:46:54 +0000 | [diff] [blame] | 28 | #include "llvm/Pass.h" |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 29 | #include "llvm/Support/InstIterator.h" |
Chandler Carruth | d04a8d4 | 2012-12-03 16:50:05 +0000 | [diff] [blame] | 30 | #include "llvm/Target/TargetLibraryInfo.h" |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 31 | #include <set> |
Chris Lattner | d745602 | 2004-01-09 06:02:20 +0000 | [diff] [blame] | 32 | using namespace llvm; |
Brian Gaeke | d0fde30 | 2003-11-11 22:41:34 +0000 | [diff] [blame] | 33 | |
Chris Lattner | 0e5f499 | 2006-12-19 21:40:18 +0000 | [diff] [blame] | 34 | STATISTIC(NumInstKilled, "Number of instructions killed"); |
Chris Lattner | a92f696 | 2002-10-01 22:38:41 +0000 | [diff] [blame] | 35 | |
Chris Lattner | 0e5f499 | 2006-12-19 21:40:18 +0000 | [diff] [blame] | 36 | namespace { |
Chris Lattner | 3e8b663 | 2009-09-02 06:11:42 +0000 | [diff] [blame] | 37 | struct ConstantPropagation : public FunctionPass { |
Nick Lewycky | ecd94c8 | 2007-05-06 13:37:16 +0000 | [diff] [blame] | 38 | static char ID; // Pass identification, replacement for typeid |
Owen Anderson | 081c34b | 2010-10-19 17:21:58 +0000 | [diff] [blame] | 39 | ConstantPropagation() : FunctionPass(ID) { |
| 40 | initializeConstantPropagationPass(*PassRegistry::getPassRegistry()); |
| 41 | } |
Devang Patel | 794fd75 | 2007-05-01 21:15:47 +0000 | [diff] [blame] | 42 | |
Chris Lattner | 7e70829 | 2002-06-25 16:13:24 +0000 | [diff] [blame] | 43 | bool runOnFunction(Function &F); |
Chris Lattner | 97e52e4 | 2002-04-28 21:27:06 +0000 | [diff] [blame] | 44 | |
| 45 | virtual void getAnalysisUsage(AnalysisUsage &AU) const { |
Chris Lattner | cb2610e | 2002-10-21 20:00:28 +0000 | [diff] [blame] | 46 | AU.setPreservesCFG(); |
Chad Rosier | 00737bd | 2011-12-01 21:29:16 +0000 | [diff] [blame] | 47 | AU.addRequired<TargetLibraryInfo>(); |
Chris Lattner | 97e52e4 | 2002-04-28 21:27:06 +0000 | [diff] [blame] | 48 | } |
Chris Lattner | bd0ef77 | 2002-02-26 21:46:54 +0000 | [diff] [blame] | 49 | }; |
Chris Lattner | 0095054 | 2001-06-06 20:29:01 +0000 | [diff] [blame] | 50 | } |
Chris Lattner | bd0ef77 | 2002-02-26 21:46:54 +0000 | [diff] [blame] | 51 | |
Dan Gohman | 844731a | 2008-05-13 00:00:25 +0000 | [diff] [blame] | 52 | char ConstantPropagation::ID = 0; |
Chad Rosier | 00737bd | 2011-12-01 21:29:16 +0000 | [diff] [blame] | 53 | INITIALIZE_PASS_BEGIN(ConstantPropagation, "constprop", |
| 54 | "Simple constant propagation", false, false) |
| 55 | INITIALIZE_PASS_DEPENDENCY(TargetLibraryInfo) |
| 56 | INITIALIZE_PASS_END(ConstantPropagation, "constprop", |
Owen Anderson | ce665bd | 2010-10-07 22:25:06 +0000 | [diff] [blame] | 57 | "Simple constant propagation", false, false) |
Dan Gohman | 844731a | 2008-05-13 00:00:25 +0000 | [diff] [blame] | 58 | |
Chris Lattner | 4b50156 | 2004-09-20 04:43:15 +0000 | [diff] [blame] | 59 | FunctionPass *llvm::createConstantPropagationPass() { |
Misha Brukman | 82c89b9 | 2003-05-20 21:01:22 +0000 | [diff] [blame] | 60 | return new ConstantPropagation(); |
Chris Lattner | bd0ef77 | 2002-02-26 21:46:54 +0000 | [diff] [blame] | 61 | } |
| 62 | |
Misha Brukman | 82c89b9 | 2003-05-20 21:01:22 +0000 | [diff] [blame] | 63 | bool ConstantPropagation::runOnFunction(Function &F) { |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 64 | // Initialize the worklist to all of the instructions ready to process... |
Chris Lattner | 6ffe551 | 2004-04-27 15:13:33 +0000 | [diff] [blame] | 65 | std::set<Instruction*> WorkList; |
| 66 | for(inst_iterator i = inst_begin(F), e = inst_end(F); i != e; ++i) { |
| 67 | WorkList.insert(&*i); |
| 68 | } |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 69 | bool Changed = false; |
Micah Villmow | 3574eca | 2012-10-08 16:38:25 +0000 | [diff] [blame] | 70 | DataLayout *TD = getAnalysisIfAvailable<DataLayout>(); |
Chad Rosier | 00737bd | 2011-12-01 21:29:16 +0000 | [diff] [blame] | 71 | TargetLibraryInfo *TLI = &getAnalysis<TargetLibraryInfo>(); |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 72 | |
| 73 | while (!WorkList.empty()) { |
| 74 | Instruction *I = *WorkList.begin(); |
| 75 | WorkList.erase(WorkList.begin()); // Get an element from the worklist... |
| 76 | |
| 77 | if (!I->use_empty()) // Don't muck with dead instructions... |
Chad Rosier | 00737bd | 2011-12-01 21:29:16 +0000 | [diff] [blame] | 78 | if (Constant *C = ConstantFoldInstruction(I, TD, TLI)) { |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 79 | // Add all of the users of this instruction to the worklist, they might |
Misha Brukman | 82c89b9 | 2003-05-20 21:01:22 +0000 | [diff] [blame] | 80 | // be constant propagatable now... |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 81 | for (Value::use_iterator UI = I->use_begin(), UE = I->use_end(); |
| 82 | UI != UE; ++UI) |
| 83 | WorkList.insert(cast<Instruction>(*UI)); |
Misha Brukman | fd93908 | 2005-04-21 23:48:37 +0000 | [diff] [blame] | 84 | |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 85 | // Replace all of the uses of a variable with uses of the constant. |
| 86 | I->replaceAllUsesWith(C); |
Chris Lattner | 3dec1f2 | 2002-05-10 15:38:35 +0000 | [diff] [blame] | 87 | |
Chris Lattner | 4647b7c | 2004-04-13 19:28:20 +0000 | [diff] [blame] | 88 | // Remove the dead instruction. |
| 89 | WorkList.erase(I); |
Dan Gohman | 1adec83 | 2008-06-21 22:08:46 +0000 | [diff] [blame] | 90 | I->eraseFromParent(); |
Chris Lattner | 4647b7c | 2004-04-13 19:28:20 +0000 | [diff] [blame] | 91 | |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 92 | // We made a change to the function... |
| 93 | Changed = true; |
Chris Lattner | 3dec1f2 | 2002-05-10 15:38:35 +0000 | [diff] [blame] | 94 | ++NumInstKilled; |
Chris Lattner | 89df1b5 | 2002-05-06 18:21:31 +0000 | [diff] [blame] | 95 | } |
| 96 | } |
| 97 | return Changed; |
| 98 | } |