#include "irgraph.h"
#include "irgwalk.h"
+#include "irdump_t.h"
#include "ircons.h"
#include "iropt.h"
#include "irgopt.h"
#include "beutil.h"
#include "besched_t.h"
-#include "bera_t.h"
#include "bearch.h"
struct dump_env {
if(block != get_irg_start_block(get_irn_irg(block))) {
for(i = 0, n = get_irn_arity(irn); i < n; ++i) {
ir_node *op = get_irn_n(irn, i);
- if(is_allocatable_irn(op)) {
+ if(arch_is_register_operand(dump_env->env, op, arch_pos_make_out(0))) {
ir_fprintf(f, "%s%s", prefix,
arch_register_get_name(arch_get_irn_register(env, op, 0)));
prefix = ", ";
irg_walk_graph(irg, localize_const_walker, NULL, NULL);
dead_node_elimination(irg);
}
+
+static int sched_edge_hook(FILE *F, ir_node *irn)
+{
+ if(sched_is_scheduled(irn) && sched_has_prev(irn)) {
+ ir_node *prev = sched_prev(irn);
+ fprintf(F, "edge:{sourcename:\"");
+ PRINT_NODEID(irn);
+ fprintf(F, "\" targetname:\"");
+ PRINT_NODEID(prev);
+ fprintf(F, "\" color:magenta}\n");
+ }
+ return 1;
+}
+
+void dump_ir_block_graph_sched(ir_graph *irg, const char *suffix) {
+ DUMP_NODE_EDGE_FUNC old = get_dump_node_edge_hook();
+
+ set_dump_node_edge_hook(sched_edge_hook);
+ dump_ir_block_graph(irg, suffix);
+ set_dump_node_edge_hook(old);
+}