give Bad nodes a mode
[libfirm] / ir / be / sparc / sparc_cconv.h
1 /*
2  * Copyright (C) 1995-2010 University of Karlsruhe.  All right reserved.
3  *
4  * This file is part of libFirm.
5  *
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.
10  *
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.
14  *
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
17  * PURPOSE.
18  */
19
20 /**
21  * @file
22  * @brief   support functions for calling conventions
23  * @author  Matthias Braun
24  * @version $Id$
25  */
26 #ifndef FIRM_BE_SPARC_SPARC_CCONV_H
27 #define FIRM_BE_SPARC_SPARC_CCONV_H
28
29 #include "firm_types.h"
30 #include "../be_types.h"
31 #include "gen_sparc_regalloc_if.h"
32
33 static const arch_register_t *const caller_saves[] = {
34         &sparc_registers[REG_G1],
35         &sparc_registers[REG_G2],
36         &sparc_registers[REG_G3],
37         &sparc_registers[REG_G4],
38         &sparc_registers[REG_O0],
39         &sparc_registers[REG_O1],
40         &sparc_registers[REG_O2],
41         &sparc_registers[REG_O3],
42         &sparc_registers[REG_O4],
43         &sparc_registers[REG_O5],
44
45         &sparc_registers[REG_F0],
46         &sparc_registers[REG_F1],
47         &sparc_registers[REG_F2],
48         &sparc_registers[REG_F3],
49         &sparc_registers[REG_F4],
50         &sparc_registers[REG_F5],
51         &sparc_registers[REG_F6],
52         &sparc_registers[REG_F7],
53         &sparc_registers[REG_F8],
54         &sparc_registers[REG_F9],
55         &sparc_registers[REG_F10],
56         &sparc_registers[REG_F11],
57         &sparc_registers[REG_F12],
58         &sparc_registers[REG_F13],
59         &sparc_registers[REG_F14],
60         &sparc_registers[REG_F15],
61         &sparc_registers[REG_F16],
62         &sparc_registers[REG_F17],
63         &sparc_registers[REG_F18],
64         &sparc_registers[REG_F19],
65         &sparc_registers[REG_F20],
66         &sparc_registers[REG_F21],
67         &sparc_registers[REG_F22],
68         &sparc_registers[REG_F23],
69         &sparc_registers[REG_F24],
70         &sparc_registers[REG_F25],
71         &sparc_registers[REG_F26],
72         &sparc_registers[REG_F27],
73         &sparc_registers[REG_F28],
74         &sparc_registers[REG_F29],
75         &sparc_registers[REG_F30],
76         &sparc_registers[REG_F31],
77 };
78
79 static const arch_register_t *const omit_fp_callee_saves[] = {
80         &sparc_registers[REG_L0],
81         &sparc_registers[REG_L1],
82         &sparc_registers[REG_L2],
83         &sparc_registers[REG_L3],
84         &sparc_registers[REG_L4],
85         &sparc_registers[REG_L5],
86         &sparc_registers[REG_L6],
87         &sparc_registers[REG_L7],
88         &sparc_registers[REG_I0],
89         &sparc_registers[REG_I1],
90         &sparc_registers[REG_I2],
91         &sparc_registers[REG_I3],
92         &sparc_registers[REG_I4],
93         &sparc_registers[REG_I5],
94 };
95
96 static const arch_register_t* const param_regs[] = {
97         &sparc_registers[REG_I0],
98         &sparc_registers[REG_I1],
99         &sparc_registers[REG_I2],
100         &sparc_registers[REG_I3],
101         &sparc_registers[REG_I4],
102         &sparc_registers[REG_I5],
103 };
104
105 static const arch_register_t* const float_result_regs[] = {
106         &sparc_registers[REG_F0],
107         &sparc_registers[REG_F1],
108         &sparc_registers[REG_F2],
109         &sparc_registers[REG_F3],
110 };
111
112 /** information about a single parameter or result */
113 typedef struct reg_or_stackslot_t
114 {
115         const arch_register_t *reg0;   /**< if != NULL, the first register used for
116                                             this parameter. */
117         const arch_register_t *reg1;   /**< if != NULL, the second register used. */
118         ir_type               *type;   /**< indicates that an entity of the specific
119                                                                             type is needed */
120         int                    offset; /**< if transmitted via stack, the offset for
121                                             this parameter. */
122         ir_entity             *entity; /**< entity in frame type */
123 } reg_or_stackslot_t;
124
125 /** The calling convention info for one call site. */
126 typedef struct calling_convention_t
127 {
128         bool                omit_fp;          /**< do not use frame pointer (and no
129                                                    save/restore) */
130         reg_or_stackslot_t *parameters;       /**< parameter info. */
131         int                 param_stack_size; /**< stack size for parameters */
132         reg_or_stackslot_t *results;          /**< result info. */
133 } calling_convention_t;
134
135 /**
136  * Determine how function parameters and return values are passed.
137  * Decides what goes to register or to stack and what stack offsets/
138  * datatypes are used.
139  *
140  * @param function_type  the type of the caller/callee function
141  * @param caller         true for convention for the caller, false for callee
142  */
143 calling_convention_t *sparc_decide_calling_convention(ir_type *function_type,
144                                                       ir_graph *irg);
145
146 /**
147  * free memory used by a calling_convention_t
148  */
149 void sparc_free_calling_convention(calling_convention_t *cconv);
150
151 #endif