00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037 #ifndef CBZ_SSA_H
00038 #define CBZ_SSA_H
00039
00040 #include <bitset>
00041 #include "clone_changer.h"
00042 #include "dismantle.h"
00043 #include "dominators.h"
00044 #include "dominancefrontiers.h"
00045
00046 class ssa_info : public algorithm_info
00047 {
00048 public:
00049
00050 int HasAlready;
00051 int Work;
00052
00053 ssa_info()
00054 : HasAlready(0), Work(0)
00055 {}
00056 };
00057
00058 typedef vector<basicblockNode *> basicblock_vec;
00059
00060 typedef map<declNode *, int_list> varstack_map;
00061
00062 typedef map<declNode *, int> counter_map;
00063 typedef counter_map::iterator counter_map_p;
00064
00065 typedef map<basicblockNode *, basicblock_bitset> basicblockset_map;
00066 typedef basicblockset_map::iterator basicblockset_map_p;
00067
00068 typedef pair< idNode * , int > var_change;
00069 typedef list< var_change > var_changes;
00070 typedef var_changes::iterator var_changes_p;
00071
00072 typedef vector< declNode * > decl_vector;
00073 typedef map< declNode *, decl_vector > decl_decl_map;
00074
00075 class SSA
00076 {
00077 private:
00078
00079
00080
00081 const procNode * _proc;
00082
00083
00084
00085 basicblockNode * _root;
00086 basicblock_list _cfg;
00087
00088
00089
00090
00091
00092
00093
00094 varstack_map Stack;
00095 counter_map Counter;
00096 var_changes Changes;
00097
00098
00099
00100 DominanceFrontiers DF;
00101
00102 private:
00103
00104
00105
00106 void place_phi_functions();
00107 static void place_one_phi(declNode * d, basicblockNode * block);
00108
00109
00110
00111 void rename();
00112 void search(basicblockNode * X);
00113 int which_pred(basicblockNode * node, basicblockNode * pred);
00114 void push_new_decl(declNode * de, int index);
00115 void rename_all_variables();
00116 string name_with_index(string & name, int index);
00117
00118
00119
00120 static int & HasAlready(basicblockNode * n)
00121 {
00122 return ((ssa_info *)(n)->info())->HasAlready;
00123 }
00124
00125 static int & Work(basicblockNode * n)
00126 {
00127 return ((ssa_info *)(n)->info())->Work;
00128 }
00129
00130 public:
00131
00132 SSA(procNode * proc, bool forward = true, bool rename = true);
00133
00134 void print() {}
00135
00136
00137
00138 static binaryNode * assignment(stmtNode * s);
00139 static idNode * lhs(stmtNode * s);
00140 static callNode * phi(stmtNode * s);
00141 void record_index(idNode * id);
00142
00143
00144
00145 static bool add_phi_function(declNode * d, basicblockNode * block);
00146
00147 };
00148
00149 #endif // CBZ_SSA_H