blob: b8e1d7b46f99ca2c0bacb2bfd40921b3c8c5f9bf [file] [log] [blame]
Chris Lattner1bffea02001-10-15 17:31:51 +00001//===- llvm/Transforms/HoistPHIConstants.h - Normalize PHI nodes ------------=//
2//
3// HoistPHIConstants - Remove literal constants that are arguments of PHI nodes
4// by inserting cast instructions in the preceeding basic blocks, and changing
5// constant references into references of the casted value.
6//
7//===----------------------------------------------------------------------===//
8
Ruchira Sasankafca59d72001-11-03 17:09:59 +00009
10
11
Chris Lattner1bffea02001-10-15 17:31:51 +000012#include "llvm/Transforms/HoistPHIConstants.h"
13#include "llvm/iOther.h"
14#include "llvm/BasicBlock.h"
15#include "llvm/Method.h"
16#include <map>
17
18typedef pair<BasicBlock *, Value*> BBConstTy;
19typedef map<BBConstTy, CastInst *> CachedCopyMap;
20
21static Value *NormalizePhiOperand(PHINode *PN, Value *CPV,
22 BasicBlock *Pred, CachedCopyMap &CopyCache) {
23
Ruchira Sasankafca59d72001-11-03 17:09:59 +000024 /* NOTE: CahedCopyMap was disabled to insert phi elimination code
25 for all phi args -- Ruchira
26 */
27
28
Chris Lattner1bffea02001-10-15 17:31:51 +000029 // Check if we've already inserted a copy for this constant in Pred
30 // Note that `copyCache[Pred]' will create an empty vector the first time
31 //
Ruchira Sasankafca59d72001-11-03 17:09:59 +000032 //CachedCopyMap::iterator CCI = CopyCache.find(BBConstTy(Pred, CPV));
33 //if (CCI != CopyCache.end()) return CCI->second;
Chris Lattner1bffea02001-10-15 17:31:51 +000034
35 // Create a copy instruction and add it to the cache...
36 CastInst *Inst = new CastInst(CPV, CPV->getType());
Ruchira Sasankafca59d72001-11-03 17:09:59 +000037 //CopyCache.insert(make_pair(BBConstTy(Pred, CPV), Inst));
Chris Lattner1bffea02001-10-15 17:31:51 +000038
39 // Insert the copy just before the terminator inst of the predecessor BB
40 assert(Pred->getTerminator() && "Degenerate BB encountered!");
41 Pred->getInstList().insert(Pred->getInstList().end()-1, Inst);
42
43 return Inst;
44}
45
46
47//---------------------------------------------------------------------------
48// Entry point for normalizing constant args in PHIs
49//---------------------------------------------------------------------------
50
Chris Lattner42c9c2c2001-10-18 05:27:33 +000051bool HoistPHIConstants::doHoistPHIConstants(Method *M) {
Chris Lattner1bffea02001-10-15 17:31:51 +000052 CachedCopyMap Cache;
Chris Lattner42c9c2c2001-10-18 05:27:33 +000053 bool Changed = false;
Chris Lattner1bffea02001-10-15 17:31:51 +000054
55 for (Method::iterator BI = M->begin(), BE = M->end(); BI != BE; ++BI)
56 for (BasicBlock::iterator II = (*BI)->begin(); II != (*BI)->end(); ++II) {
57 Instruction *Inst = *II;
58 if (!isa<PHINode>(Inst)) break; // All PHIs occur at top of BB!
59
60 PHINode *PN = cast<PHINode>(Inst);
61 for (unsigned i = 0; i < PN->getNumIncomingValues(); ++i) {
62 Value *Op = PN->getIncomingValue(i);
Ruchira Sasankafca59d72001-11-03 17:09:59 +000063
64 //if (isa<ConstPoolVal>(Op)) { --- Do for all phi args -- Ruchira
65
66 PN->setIncomingValue(i,
67 NormalizePhiOperand(PN, Op, PN->getIncomingBlock(i), Cache));
68 Changed = true;
69
70 //}
Chris Lattner1bffea02001-10-15 17:31:51 +000071 }
72 }
73
Chris Lattner42c9c2c2001-10-18 05:27:33 +000074 return Changed;
Chris Lattner1bffea02001-10-15 17:31:51 +000075}