/* Plugin for testing dumpfile.c. */ #define INCLUDE_MEMORY #include "gcc-plugin.h" #include "config.h" #include "system.h" #include "coretypes.h" #include "tree.h" #include "tree-pass.h" #include "intl.h" #include "plugin-version.h" #include "diagnostic.h" #include "context.h" #include "optinfo.h" #include "gimple.h" #include "gimple-iterator.h" #include "cgraph.h" int plugin_is_GPL_compatible; const pass_data pass_data_test_dumping = { GIMPLE_PASS, /* type */ "test_dumping", /* name */ OPTGROUP_LOOP, /* optinfo_flags */ TV_NONE, /* tv_id */ PROP_ssa, /* properties_required */ 0, /* properties_provided */ 0, /* properties_destroyed */ 0, /* todo_flags_start */ 0, /* todo_flags_finish */ }; class pass_test_dumping : public gimple_opt_pass { public: pass_test_dumping (gcc::context *ctxt) : gimple_opt_pass (pass_data_test_dumping, ctxt) {} /* opt_pass methods: */ bool gate (function *) { return true; } virtual unsigned int execute (function *); }; // class pass_test_dumping unsigned int pass_test_dumping::execute (function *fun) { basic_block bb; if (!dump_enabled_p ()) return 0; FOR_ALL_BB_FN (bb, fun) for (gimple_stmt_iterator gsi = gsi_start_bb (bb); !gsi_end_p (gsi); gsi_next (&gsi)) { gimple *stmt = gsi_stmt (gsi); gcall *call = dyn_cast (stmt); if (!call) continue; tree callee_decl = gimple_call_fndecl (call); if (!callee_decl) continue; tree callee_name = DECL_NAME (callee_decl); if (!callee_name) continue; const char *callee = IDENTIFIER_POINTER (callee_name); /* Various dumping tests, done at callsites, controlled by the callee name. */ if (strcmp (callee, "test_string_literal") == 0) dump_printf_loc (MSG_NOTE, stmt, "test of dump for %qs\n", callee); else if (strcmp (callee, "test_tree") == 0) dump_printf_loc (MSG_NOTE, stmt, "test of tree: %T\n", integer_zero_node); else if (strcmp (callee, "test_gimple") == 0) dump_printf_loc (MSG_NOTE, stmt, "test of gimple: %G", stmt); else if (strcmp (callee, "test_cgraph_node") == 0) { dump_printf_loc (MSG_NOTE, stmt, "test of callgraph node: "); dump_symtab_node (MSG_NOTE, cgraph_node::get (callee_decl)); dump_printf (MSG_NOTE, "\n"); } else if (strcmp (callee, "test_wide_int") == 0) { HOST_WIDE_INT val = 0; dump_printf_loc (MSG_NOTE, stmt, "test of wide int: " HOST_WIDE_INT_PRINT_DEC "\n", val); } else if (strcmp (callee, "test_poly_int") == 0) { dump_printf_loc (MSG_NOTE, stmt, "test of poly int: "); dump_dec (MSG_NOTE, poly_int64 (42)); dump_printf (MSG_NOTE, "\n"); } else if (strcmp (callee, "test_scopes") == 0) { AUTO_DUMP_SCOPE ("outer scope", stmt); { dump_printf_loc (MSG_NOTE, stmt, "at outer scope\n"); AUTO_DUMP_SCOPE ("middle scope", stmt); { dump_printf_loc (MSG_NOTE, stmt, "at middle scope\n"); AUTO_DUMP_SCOPE ("innermost scope", stmt); dump_printf_loc (MSG_NOTE, stmt, "at innermost scope\n"); } } } } return 0; } static gimple_opt_pass * make_pass_test_dumping (gcc::context *ctxt) { return new pass_test_dumping (ctxt); } int plugin_init (struct plugin_name_args *plugin_info, struct plugin_gcc_version *version) { struct register_pass_info pass_info; const char *plugin_name = plugin_info->base_name; int argc = plugin_info->argc; struct plugin_argument *argv = plugin_info->argv; if (!plugin_default_version_check (version, &gcc_version)) return 1; pass_info.pass = make_pass_test_dumping (g); pass_info.reference_pass_name = "ssa"; pass_info.ref_pass_instance_number = 1; pass_info.pos_op = PASS_POS_INSERT_AFTER; register_callback (plugin_name, PLUGIN_PASS_MANAGER_SETUP, NULL, &pass_info); return 0; }