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
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093 #ifndef HB_PATH_H_INCLUDED
00094 #define HB_PATH_H_INCLUDED
00095
00096 #include "cg_sched_est.h"
00097 #include "bb_set.h"
00098
00100
00101
00102
00104
00105 struct HB_PATH {
00106 float hazard_multiplier;
00107 float probability;
00108 float priority;
00109 INT num_ops;
00110 INT num_cb_ops;
00111 INT num_ucb_ops;
00112 CG_SCHED_EST* sched_est;
00113 BB_SET* blocks;
00114 };
00115
00116
00118 inline float
00119 HB_PATH_Hazard_Multiplier(HB_PATH* hb_path)
00121
00123 {
00124 return hb_path->hazard_multiplier;
00125 }
00126
00128 inline void
00129 HB_PATH_Hazard_Multiplier_Set(HB_PATH* hb_path, float hazard_multiplier)
00131
00133 {
00134 hb_path->hazard_multiplier = hazard_multiplier;
00135 }
00136
00138 inline float
00139 HB_PATH_Probability(HB_PATH* hb_path)
00141
00143 {
00144 return hb_path->probability;
00145 }
00146
00148 inline void
00149 HB_PATH_Probability_Set(HB_PATH* hb_path, float probability)
00151
00153 {
00154 hb_path->probability = probability;
00155 }
00156
00157
00159 inline float
00160 HB_PATH_Priority(HB_PATH* hb_path)
00162
00164 {
00165 return hb_path->priority;
00166 }
00167
00169 inline void
00170 HB_PATH_Priority_Set(HB_PATH* hb_path, float priority)
00172
00174 {
00175 hb_path->priority = priority;
00176 }
00177
00178
00180 inline INT
00181 HB_PATH_Num_Ops(HB_PATH* hb_path)
00183
00185 {
00186 return hb_path->num_ops;
00187 }
00188
00190 inline void
00191 HB_PATH_Num_Ops_Set(HB_PATH* hb_path, INT num_ops)
00193
00195 {
00196 hb_path->num_ops = num_ops;
00197 }
00198
00200 inline INT
00201 HB_PATH_Num_CBranch_Ops(HB_PATH* hb_path)
00203
00205 {
00206 return hb_path->num_cb_ops;
00207 }
00208
00210 inline void
00211 HB_PATH_Num_CB_Ops_Set(HB_PATH* hb_path, INT num_cb_ops)
00213
00215 {
00216 hb_path->num_cb_ops = num_cb_ops;
00217 }
00218
00220 inline INT
00221 HB_PATH_Num_UCBranch_Ops(HB_PATH* hb_path)
00223
00225 {
00226 return hb_path->num_ucb_ops;
00227 }
00228
00230 inline void
00231 HB_PATH_Num_UCB_Ops_Set(HB_PATH* hb_path, INT num_ucb_ops)
00233
00235 {
00236 hb_path->num_ucb_ops = num_ucb_ops;
00237 }
00238
00240 inline CG_SCHED_EST*
00241 HB_PATH_Sched_Est(HB_PATH* hb_path)
00243
00245 {
00246 return hb_path->sched_est;
00247 }
00248
00250 inline void
00251 HB_PATH_Sched_Est_Set(HB_PATH* hb_path, CG_SCHED_EST* sched_est)
00253
00255 {
00256 hb_path->sched_est = sched_est;
00257 }
00258
00260 inline INT
00261 HB_PATH_Schedule_Height(HB_PATH* hb_path)
00263
00265 {
00266 if (HB_PATH_Sched_Est(hb_path)) {
00267 return CG_SCHED_EST_Resource_Cycles(HB_PATH_Sched_Est(hb_path));
00268 }
00269 return 0;
00270 }
00271
00273 inline BB_SET*
00274 HB_PATH_Blocks(HB_PATH* hb_path)
00276
00278 {
00279 return hb_path->blocks;
00280 }
00281
00283 inline void
00284 HB_PATH_Blocks_Set(HB_PATH* hb_path, BB_SET* bb_set)
00286
00288 {
00289 hb_path->blocks = bb_set;
00290 }
00291
00293 inline void
00294 HB_PATH_Add_Block(HB_PATH* hb_path, BB* bb, MEM_POOL* pool)
00296
00298 {
00299 BB_SET *blocks = HB_PATH_Blocks(hb_path);
00300 blocks = BB_SET_Union1D(blocks, bb, pool);
00301 }
00302
00304 inline void
00305 HB_PATH_Add_BB_SET(HB_PATH* hb_path, BB_SET* bb_set, MEM_POOL* pool)
00307
00309 {
00310 BB_SET *blocks = HB_PATH_Blocks(hb_path);
00311 blocks = BB_SET_UnionD(blocks, bb_set, pool);
00312 }
00313
00314
00316 inline void
00317 HB_PATH_Remove_Block(HB_PATH* hb_path, BB* bb, MEM_POOL* pool)
00319
00321 {
00322 BB_SET *blocks = HB_PATH_Blocks(hb_path);
00323 blocks = BB_SET_Difference1D(blocks, bb);
00324 }
00325
00327 inline BOOL
00328 HB_PATH_Contains_Block(HB_PATH* hb_path, BB* bb)
00330
00332 {
00333 return BB_SET_MemberP(HB_PATH_Blocks(hb_path), bb);
00334 }
00335
00337 inline HB_PATH*
00338 HB_PATH_Alloc(MEM_POOL* pool)
00340
00342 {
00343 HB_PATH* hb_path = TYPE_MEM_POOL_ALLOC(HB_PATH, pool);
00344 HB_PATH_Blocks_Set(hb_path,BB_SET_Create_Empty(PU_BB_Count+2, pool));
00345 HB_PATH_Hazard_Multiplier_Set(hb_path, 1.0);
00346 HB_PATH_Probability_Set(hb_path, 1.0);
00347 HB_PATH_Priority_Set(hb_path, 0.0);
00348 HB_PATH_Num_Ops_Set(hb_path, 0);
00349 return hb_path;
00350 }
00351
00352
00354
00355
00356
00357
00359 struct HB_PATH_Priority_Compare {
00360 BOOL operator () (HB_PATH* p1, HB_PATH* p2) {
00361 return HB_PATH_Priority(p1) > HB_PATH_Priority(p2);
00362 }
00363 };
00364
00365 #endif