blob: 442eb22c7310810a101900519de4ab66ed7792d9 [file] [log] [blame]
Chris Lattner01744102002-02-05 00:33:19 +00001//===-- BBLiveVar.h - Live Variable Analysis for a BasicBlock ----*- C++ -*--=//
2//
3// This is a wrapper class for BasicBlock which is used by live var analysis.
4//
5//===----------------------------------------------------------------------===//
Ruchira Sasanka683847f2001-07-24 17:14:13 +00006
7#ifndef LIVE_VAR_BB_H
8#define LIVE_VAR_BB_H
9
Chris Lattner5e5dfa32002-02-05 02:51:01 +000010#include "llvm/Analysis/LiveVar/ValueSet.h"
Chris Lattner01744102002-02-05 00:33:19 +000011#include <map>
Chris Lattner65b1ad92002-02-04 16:31:03 +000012class Method;
Chris Lattner01744102002-02-05 00:33:19 +000013class BasicBlock;
14class Value;
Ruchira Sasanka683847f2001-07-24 17:14:13 +000015
Chris Lattner65b1ad92002-02-04 16:31:03 +000016class BBLiveVar {
Chris Lattner01744102002-02-05 00:33:19 +000017 const BasicBlock *BB; // pointer to BasicBlock
18 unsigned POID; // Post-Order ID
Ruchira Sasanka683847f2001-07-24 17:14:13 +000019
Chris Lattner5e5dfa32002-02-05 02:51:01 +000020 ValueSet DefSet; // Def set for LV analysis
21 ValueSet InSet, OutSet; // In & Out for LV analysis
Ruchira Sasanka683847f2001-07-24 17:14:13 +000022 bool InSetChanged, OutSetChanged; // set if the InSet/OutSet is modified
23
24 // map that contains phi args->BB they came
Ruchira Sasanka91661812001-08-20 21:11:01 +000025 // set by calcDefUseSets & used by setPropagate
Chris Lattner01744102002-02-05 00:33:19 +000026 std::map<const Value *, const BasicBlock *> PhiArgMap;
Ruchira Sasanka683847f2001-07-24 17:14:13 +000027
Ruchira Sasanka91661812001-08-20 21:11:01 +000028 // method to propogate an InSet to OutSet of a predecessor
Chris Lattner5e5dfa32002-02-05 02:51:01 +000029 bool setPropagate(ValueSet *OutSetOfPred,
30 const ValueSet *InSetOfThisBB,
Chris Lattner01744102002-02-05 00:33:19 +000031 const BasicBlock *PredBB);
Ruchira Sasanka683847f2001-07-24 17:14:13 +000032
Ruchira Sasanka598641b2001-10-12 17:46:27 +000033 // To add an operand which is a def
Chris Lattner748697d2002-02-05 04:20:12 +000034 void addDef(const Value *Op);
Ruchira Sasanka598641b2001-10-12 17:46:27 +000035
36 // To add an operand which is a use
Chris Lattner748697d2002-02-05 04:20:12 +000037 void addUse(const Value *Op);
Ruchira Sasanka598641b2001-10-12 17:46:27 +000038
Chris Lattner748697d2002-02-05 04:20:12 +000039 void calcDefUseSets(); // calculates the Def & Use sets for this BB
Ruchira Sasanka683847f2001-07-24 17:14:13 +000040 public:
Chris Lattner01744102002-02-05 00:33:19 +000041 BBLiveVar(const BasicBlock *BB, unsigned POID);
Ruchira Sasanka683847f2001-07-24 17:14:13 +000042
Chris Lattner01744102002-02-05 00:33:19 +000043 inline bool isInSetChanged() const { return InSetChanged; }
Ruchira Sasanka683847f2001-07-24 17:14:13 +000044 inline bool isOutSetChanged() const { return OutSetChanged; }
45
Chris Lattner01744102002-02-05 00:33:19 +000046 inline unsigned getPOId() const { return POID; }
Ruchira Sasanka683847f2001-07-24 17:14:13 +000047
Chris Lattner01744102002-02-05 00:33:19 +000048 bool applyTransferFunc(); // calcultes the In in terms of Out
Ruchira Sasanka683847f2001-07-24 17:14:13 +000049
Ruchira Sasanka91661812001-08-20 21:11:01 +000050 // calculates Out set using In sets of the predecessors
Chris Lattner01744102002-02-05 00:33:19 +000051 bool applyFlowFunc(std::map<const BasicBlock *, BBLiveVar *> &LVMap);
Ruchira Sasanka683847f2001-07-24 17:14:13 +000052
Chris Lattner748697d2002-02-05 04:20:12 +000053 inline const ValueSet &getOutSet() const { return OutSet; }
54 inline const ValueSet &getInSet() const { return InSet; }
Ruchira Sasanka683847f2001-07-24 17:14:13 +000055
Ruchira Sasanka91661812001-08-20 21:11:01 +000056 void printAllSets() const; // for printing Def/In/Out sets
57 void printInOutSets() const; // for printing In/Out sets
Ruchira Sasanka683847f2001-07-24 17:14:13 +000058};
59
Ruchira Sasanka683847f2001-07-24 17:14:13 +000060#endif