+typedef struct pressure_walker_env_t pressure_walker_env_t;
+struct pressure_walker_env_t {
+ be_irg_t *birg;
+ be_lv_t *lv;
+ double insn_count;
+ double regpressure;
+ int max_pressure;
+ const arch_register_class_t *cls;
+};
+
+static void check_reg_pressure_class(pressure_walker_env_t *env,
+ ir_node *block,
+ const arch_register_class_t *cls)
+{
+ be_irg_t *birg = env->birg;
+ ir_graph *irg = be_get_birg_irg(birg);
+ const arch_env_t *aenv = be_get_birg_arch_env(birg);
+ ir_node *irn;
+ ir_nodeset_t live_nodes;
+ int max_live;
+
+ ir_nodeset_init(&live_nodes);
+ be_liveness_end_of_block(env->lv, aenv, cls, block, &live_nodes);
+ max_live = ir_nodeset_size(&live_nodes);
+ env->regpressure += max_live;
+
+ sched_foreach_reverse(block, irn) {
+ int cnt;
+
+ if(is_Phi(irn))
+ break;
+
+ be_liveness_transfer(aenv, cls, irn, &live_nodes);
+ cnt = ir_nodeset_size(&live_nodes);
+ max_live = cnt < max_live ? max_live : cnt;
+ env->regpressure += cnt;
+ env->insn_count++;
+ }
+
+ if(max_live > env->max_pressure)
+ env->max_pressure = max_live;
+
+ stat_be_block_regpressure(irg, block, max_live, cls->name);
+ ir_nodeset_destroy(&live_nodes);
+}
+