bestat.h 3.61 KB
Newer Older
Christian Würdig's avatar
Christian Würdig committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
/*
 * Copyright (C) 1995-2007 University of Karlsruhe.  All right reserved.
 *
 * This file is part of libFirm.
 *
 * This file may be distributed and/or modified under the terms of the
 * GNU General Public License version 2 as published by the Free Software
 * Foundation and appearing in the file LICENSE.GPL included in the
 * packaging of this file.
 *
 * Licensees holding valid libFirm Professional Edition licenses may use
 * this file in accordance with the libFirm Commercial License.
 * Agreement provided with the Software.
 *
 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE.
 */

Christian Würdig's avatar
Christian Würdig committed
20
21
22
23
24
25
/**
 * Provides several statistic functions for the backend.
 * @author Christian Wuerdig
 * $Id$
 */

26
27
28
#ifndef _BESTAT_H_
#define _BESTAT_H_

29
#include "firm_config.h"
30
#include "be_t.h"
31
#include "benodesets.h"
32
33
34
35
36
37
38
39
40
41
42
43
44
#include "bestatevent.h"

enum {
	STAT_TAG_FILE = 0,  /**< tag for source file name */
	STAT_TAG_TIME = 1,  /**< tag for time */
	STAT_TAG_IRG  = 2,  /**< tag for function name (irg) */
	STAT_TAG_CLS  = 3,  /**< tag for register class (or "<all>") */
	STAT_TAG_LAST
};

extern FILE *be_stat_file;
extern const char *be_stat_tags[STAT_TAG_LAST];

45

46
47
#ifdef FIRM_STATISTICS

48
49
50
51
52
53
/**
 * Collects statistics information about register pressure.
 * @param birg The be irg object containing the irg
 */
void be_do_stat_reg_pressure(be_irg_t *birg);

54
/**
55
 * Collect statistics about amount of ready nodes per block
56
57
58
 * @param block     The block
 * @param ready_set A set of ready nodes
 */
59
void be_do_stat_sched_ready(ir_node *block, const ir_nodeset_t *ready_set);
60

Christian Würdig's avatar
Christian Würdig committed
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/**
 * Pass information about a perm to the statistic module.
 *
 * @param class_name the name of the register class
 * @param n_regs     number of registers in the register class
 * @param perm       the perm node
 * @param block      the block containing the perm
 * @param size       the size of the perm
 * @param real_size  number of pairs with different registers
 */
void be_do_stat_perm(const char *class_name, int n_regs, ir_node *perm, ir_node *block, int n, int real_size);

/**
 * Pass information about a cycle or chain in a perm to the statistic module.
 *
 * @param class_name the name of the register class
 * @param perm       the perm node
 * @param block      the block containing the perm
 * @param is_chain   1 if chain, 0 if cycle
 * @param size       length of the cycle/chain
 * @param n_ops      the number of ops representing this cycle/chain after lowering
 */
void be_do_stat_permcycle(const char *class_name, ir_node *perm, ir_node *block, int is_chain, int n_elems, int n_ops);

Christian Würdig's avatar
Christian Würdig committed
85
86
87
88
89
90
91
92
93
94
95
96
97
/**
 * Collects node statistics.
 *
 * @param irg      the to do statistics for
 * @param phase    the phase to collect the statistic for
 */
void be_do_stat_nodes(ir_graph *irg, const char *phase);

/**
 * Performs initialization for be node statistics.
 */
void be_stat_init_irg(const arch_env_t *arch_env, ir_graph *irg);

98
void be_init_stat_file(const char *filename, const char *sourcefilename);
99
100
void be_close_stat_file(void);

101
102
#else

Christian Würdig's avatar
Christian Würdig committed
103
104
#define be_stat_init_irg(arch_env, irg)
#define be_do_stat_nodes(irg, phase)
105
106
#define be_do_stat_reg_pressure(birg)
#define be_do_stat_sched_ready(block, ready_set)
Christian Würdig's avatar
Christian Würdig committed
107
108
#define be_do_stat_perm(class_name, n_regs, perm, block, n, real_size)
#define be_do_stat_permcycle(class_name, perm, block, is_chain, n_elems, n_ops)
109
110
111

#endif /* FIRM_STATISTICS */

Matthias Braun's avatar
Matthias Braun committed
112
113
114
115
116
117
/**
 * Gives a cost estimate for the program (based on execution frequencies)
 * and backend op_estimated_cost
 */
double be_estimate_irg_costs(ir_graph *irg, const arch_env_t *arch_env, ir_exec_freq *execfreqs);

Christoph Mallon's avatar
Christoph Mallon committed
118
#endif /* _BESTAT_H_ */