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 Entry point to the representation of a whole program 0-- private header.
23 * @author Goetz Lindenmaier
27 #ifndef FIRM_IR_IRPROG_T_H
28 #define FIRM_IR_IRPROG_T_H
32 #include "pseudo_irg.h"
34 #include "irtypeinfo.h"
37 #include "callgraph.h"
38 #include "field_temperature.h"
39 #include "execution_frequency.h"
43 /** Adds mode to the list of modes in irp. */
44 void add_irp_mode(ir_mode *mode);
46 /* inline functions */
47 static inline ir_type *
48 _get_segment_type(ir_segment_t segment)
52 assert(segment < IR_SEGMENT_COUNT);
53 type = irp->segment_types[segment];
54 irp->segment_types[segment] = type;
58 static inline ir_type *
59 _get_glob_type(void) {
60 return _get_segment_type(IR_SEGMENT_GLOBAL);
63 static inline ir_type *
65 return _get_segment_type(IR_SEGMENT_THREAD_LOCAL);
69 _get_irp_n_irgs(void) {
70 assert(irp && irp->graphs);
71 if (get_visit_pseudo_irgs()) return get_irp_n_allirgs();
72 return ARR_LEN(irp->graphs);
75 static inline ir_graph *
76 _get_irp_irg(int pos){
77 if (get_visit_pseudo_irgs()) return get_irp_allirg(pos);
78 assert(0 <= pos && pos <= ARR_LEN(irp->graphs));
79 return irp->graphs[pos];
84 _get_irp_n_types(void) {
85 assert(irp && irp->types);
86 return ARR_LEN(irp->types);
89 static inline ir_type *
90 _get_irp_type(int pos) {
92 /* Don't set the skip_tid result so that no double entries are generated. */
93 return irp->types[pos];
97 _get_irp_n_modes(void) {
99 return ARR_LEN(irp->modes);
102 static inline ir_mode *
103 _get_irp_mode(int pos) {
104 assert(irp && irp->modes);
105 return irp->modes[pos];
109 _get_irp_n_opcodes(void) {
110 assert(irp && irp->opcodes);
111 return ARR_LEN(irp->opcodes);
114 static inline ir_op *
115 _get_irp_opcode(int pos) {
116 assert(irp && irp->opcodes);
117 return irp->opcodes[pos];
120 /** Returns a new, unique number to number nodes or the like. */
122 get_irp_new_node_nr(void) {
124 return irp->max_node_nr++;
128 get_irp_new_irg_idx(void) {
130 return irp->max_irg_idx++;
133 static inline ir_graph *
134 _get_const_code_irg(void) {
135 return irp->const_code_irg;
138 /** Returns a new, unique exception region number. */
139 static inline ir_exc_region_t
140 _get_irp_next_region_nr(void) {
142 return ++irp->last_region_nr;
145 /** Returns a new, unique label number. */
146 static inline ir_label_t
147 _get_irp_next_label_nr(void) {
149 return ++irp->last_label_nr;
152 void set_irp_ip_outedges(ir_node ** ip_outedges);
153 ir_node** get_irp_ip_outedges(void);
155 /** initializes ir_prog. Constructs only the basic lists */
156 void init_irprog_1(void);
158 /** Completes ir_prog. */
159 void init_irprog_2(void);
161 /* Inline functions. */
162 #define get_irp_n_irgs() _get_irp_n_irgs()
163 #define get_irp_irg(pos) _get_irp_irg(pos)
164 #define get_irp_n_types() _get_irp_n_types()
165 #define get_irp_type(pos) _get_irp_type(pos)
166 #define get_irp_n_modes() _get_irp_n_modes()
167 #define get_irp_mode(pos) _get_irp_mode(pos)
168 #define get_irp_n_opcodes() _get_irp_n_opcodes()
169 #define get_irp_opcode(pos) _get_irp_opcode(pos)
170 #define get_const_code_irg() _get_const_code_irg()
171 #define get_segment_type(s) _get_segment_type(s)
172 #define get_glob_type() _get_glob_type()
173 #define get_tls_type() _get_tls_type()
174 #define get_irp_next_region_nr() _get_irp_next_region_nr()
175 #define get_irp_next_label_nr() _get_irp_next_label_nr()