#include "access_discover.h" #include "pattern.h" #include static void print_gimple_tree(tree t, int depth, int indent = 2) { if (!t) return; for (int i = 0; i < depth; ++i) std::cout << " "; std::cout << get_tree_code_name(TREE_CODE(t)); if (TREE_CODE(t) == FIELD_DECL && DECL_NAME(t)) std::cout << " <" << IDENTIFIER_POINTER(DECL_NAME(t)) << ">"; else if (TREE_CODE(t) == SSA_NAME && SSA_NAME_VAR(t) && DECL_NAME(SSA_NAME_VAR(t))) std::cout << " "; std::cout << std::endl; for (int i = 0; i < TREE_CODE_LENGTH(TREE_CODE(t)); ++i) print_gimple_tree(TREE_OPERAND(t, i), depth + indent, indent); } static void print_gimple_statement(gimple* stmt) { if (!stmt) return; print_gimple_stmt(stdout, stmt, 0, TDF_NONE); for (unsigned i = 0; i < gimple_num_ops(stmt); ++i) { tree operand = gimple_op(stmt, i); print_gimple_tree(operand, 2, 2); } } static int scan_gimple_statement(const char* funcname, gimple_stmt_iterator* gsi) { print_gimple_statement(gsi_stmt(*gsi)); //return register_gimple_statement_pattern(gsi); return 0; } static const pass_data access_discover_pass_data = { GIMPLE_PASS, "access_discover", OPTGROUP_NONE, TV_NONE, 0,0,0,0, TODO_update_ssa | TODO_cleanup_cfg | TODO_verify_il }; access_discover_pass::access_discover_pass(gcc::context *ctxt) : gimple_opt_pass(access_discover_pass_data, ctxt) {} unsigned int access_discover_pass::execute(function* fun) { const char* funcname = fun->decl && DECL_NAME(fun->decl) ? IDENTIFIER_POINTER(DECL_NAME(fun->decl)) : ""; basic_block bb; FOR_EACH_BB_FN(bb, fun) { for (gimple_stmt_iterator gsi = gsi_start_bb(bb); !gsi_end_p(gsi); gsi_next(&gsi)) { if (scan_gimple_statement(funcname, &gsi) != 0) { internal_error("fatal error in spslr plugin: %s", "failed to scan gimple statement"); return 0; } } } clean_unnecessary_patterns(); return 0; }