2 * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved.
4 * This file is part of libFirm.
6 * This file may be distributed and/or modified under the terms of the
7 * GNU General Public License version 2 as published by the Free Software
8 * Foundation and appearing in the file LICENSE.GPL included in the
9 * packaging of this file.
11 * Licensees holding valid libFirm Professional Edition licenses may use
12 * this file in accordance with the libFirm Commercial License.
13 * Agreement provided with the Software.
15 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
16 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * @brief Instrumentation of graphs.
24 * @author Michael Beck
28 #include "irgraph_t.h"
32 #include "instrument.h"
34 void instrument_initcall(ir_graph *irg, ir_entity *ent)
36 ir_node *initial_exec;
39 ir_node *adr, *call, *new_mem;
40 ir_node *first_block = NULL;
41 int i, idx, need_new_block;
46 /* find the first block */
47 initial_exec = get_irg_initial_exec(irg);
48 start_block = get_irg_start_block(irg);
50 foreach_out_edge(initial_exec, edge) {
51 ir_node *succ = get_edge_src_irn(edge);
53 if (succ != start_block && is_Block(succ)) {
54 /* found the first block */
59 if (first_block == NULL) {
60 panic("Cannot find first block of irg %+F", irg);
63 /* check if this block has only one predecessor */
66 for (i = get_Block_n_cfgpreds(first_block) - 1; i >= 0; --i) {
67 ir_node *p = get_Block_cfgpred(first_block, i);
71 if (p == initial_exec)
78 ir_node *blk = new_r_Block(irg, 1, &initial_exec);
79 set_Block_cfgpred(first_block, idx, new_r_Jmp(blk));
85 adr = new_r_SymConst(irg, mode_P_code, sym, symconst_addr_ent);
87 call = new_r_Call(first_block, get_irg_no_mem(irg), adr, 0, NULL, get_entity_type(ent));
88 new_mem = new_r_Proj(call, mode_M, pn_Call_M);
90 initial_mem = get_irg_initial_mem(irg);
91 edges_reroute(initial_mem, new_mem);
92 /* beware: reroute routes anchor edges also, revert this */
93 set_irg_initial_mem(irg, initial_mem);
94 set_Call_mem(call, initial_mem);