* @param self The isa object.
*/
const be_machine_t *(*get_machine)(const void *self);
+
+ /**
+ * Return an ordered list of irgs where code should be generated for.
+ * If NULL is returned, all irg will be taken into account and they will be
+ * generated in an arbitrary order.
+ * @param self The isa object.
+ * @param irgs A flexible array ARR_F of length 0 where the backend cann append the desired irgs.
+ * @return A flexible array ARR_F containing all desired irgs in the desired order.
+ */
+ ir_graph **(*get_backend_irg_list)(const void *self, ir_graph **irgs);
};
#define arch_isa_get_n_reg_class(isa) ((isa)->impl->get_n_reg_class(isa))
#define arch_isa_get_reg_class_alignment(isa, cls) ((isa)->impl->get_reg_class_alignment((isa), (cls)))
#define arch_isa_get_allowed_execution_units(isa, irn) ((isa)->impl->get_allowed_execution_units((isa), (irn)))
#define arch_isa_get_machine(isa) ((isa)->impl->get_machine((isa)))
+#define arch_isa_get_backend_irg_list(isa, irgs) ((isa)->impl->get_backend_irg_list((isa), (irgs)))
#define ARCH_MAX_HANDLERS 8
static const char suffix[] = ".prof";
be_irg_t *birgs;
unsigned num_birgs;
+ ir_graph **irg_list, **backend_irg_list;
be_ra_timer_t *ra_timer;
be_dbg_so(env.db_handle, cup_name);
be_dbg_types(env.db_handle);
+ /* backend may provide an ordered list of irgs where code should be generated for */
+ irg_list = NEW_ARR_F(ir_graph *, 0);
+ backend_irg_list = arch_isa_get_backend_irg_list(isa, irg_list);
+
/* we might need 1 birg more for instrumentation constructor */
- num_birgs = get_irp_n_irgs();
+ num_birgs = backend_irg_list ? ARR_LEN(backend_irg_list) : get_irp_n_irgs();
birgs = alloca(sizeof(birgs[0]) * (num_birgs + 1));
/* First: initialize all birgs */
- for(i = 0; i < get_irp_n_irgs(); ++i) {
- ir_graph *irg = get_irp_irg(i);
+ for(i = 0; i < num_birgs; ++i) {
+ ir_graph *irg = backend_irg_list ? backend_irg_list[i] : get_irp_irg(i);
initialize_birg(&birgs[i], irg, &env);
}
+ DEL_ARR_F(irg_list);
/*
Get the filename for the profiling data.
/* For all graphs */
for (i = 0; i < num_birgs; ++i) {
- be_irg_t *birg = & birgs[i];
+ be_irg_t *birg = &birgs[i];
ir_graph *irg = birg->irg;
optimization_state_t state;
const arch_code_generator_if_t *cg_if;
return NULL;
}
+/**
+ * Return irp irgs in the desired order.
+ */
+static ir_graph **firm_get_irg_list(const void *self, ir_graph **irg_list) {
+ return NULL;
+}
+
/**
* Returns the libFirm configuration parameter for this backend.
*/
firm_get_libfirm_params,
firm_get_allowed_execution_units,
firm_get_machine,
+ firm_get_irg_list,
};
return NULL;
}
+/**
+ * Return irp irgs in the desired order.
+ */
+static ir_graph **mips_get_irg_list(const void *self, ir_graph **irg_list) {
+ return NULL;
+}
+
/**
* Returns the libFirm configuration parameter for this backend.
*/
mips_get_libfirm_params,
mips_get_allowed_execution_units,
mips_get_machine,
+ mips_get_irg_list,
};
void be_init_arch_mips(void)
return NULL;
}
+/**
+ * Return irp irgs in the desired order.
+ */
+static ir_graph **ppc32_get_irg_list(const void *self, ir_graph **irg_list) {
+ return NULL;
+}
+
/**
* Returns the libFirm configuration parameter for this backend.
*/
ppc32_get_libfirm_params,
ppc32_get_allowed_execution_units,
ppc32_get_machine,
+ ppc32_get_irg_list,
};
void be_init_arch_ppc32(void)