+static be_main_env_t *be_init_env(be_main_env_t *env)
+{
+ memset(env, 0, sizeof(*env));
+ obstack_init(&env->obst);
+ env->arch_env = obstack_alloc(&env->obst, sizeof(env->arch_env[0]));
+ env->options = &be_options;
+ FIRM_DBG_REGISTER(env->dbg, "be.main");
+
+ arch_env_init(env->arch_env, isa_if);
+
+ /* Register the irn handler of the architecture */
+ if (arch_isa_get_irn_handler(env->arch_env->isa))
+ arch_env_push_irn_handler(env->arch_env, arch_isa_get_irn_handler(env->arch_env->isa));
+
+ /*
+ * Register the node handler of the back end infrastructure.
+ * This irn handler takes care of the platform independent
+ * spill, reload and perm nodes.
+ */
+ arch_env_push_irn_handler(env->arch_env, &be_node_irn_handler);
+ env->phi_handler = be_phi_handler_new(env->arch_env);
+ arch_env_push_irn_handler(env->arch_env, env->phi_handler);
+
+ return env;
+}
+
+static void be_done_env(be_main_env_t *env)
+{
+ env->arch_env->isa->impl->done(env->arch_env->isa);
+ be_phi_handler_free(env->phi_handler);
+ obstack_free(&env->obst, NULL);
+}
+
+static void dump(int mask, ir_graph *irg, const char *suffix,
+ void (*dumper)(ir_graph *, const char *))
+{
+ if(dump_flags & mask)
+ be_dump(irg, suffix, dumper);
+}
+
+/**
+ * Prepare a backend graph for code generation.
+ */
+static void prepare_graph(be_irg_t *birg)
+{
+ ir_graph *irg = birg->irg;
+
+ /* Normalize proj nodes. */
+ normalize_proj_nodes(irg);