417f1429a933545dc70c7fd94a312ab669bc7d2d
[cacao.git] / src / vm / jit / reg.c
1 /* src/vm/jit/reg.c - register allocator setup
2
3    Copyright (C) 1996-2005, 2006, 2007 R. Grafl, A. Krall, C. Kruegel,
4    C. Oates, R. Obermaisser, M. Platter, M. Probst, S. Ring,
5    E. Steiner, C. Thalinger, D. Thuernbeck, P. Tomsich, C. Ullrich,
6    J. Wenninger, Institut f. Computersprachen - TU Wien
7
8    This file is part of CACAO.
9
10    This program is free software; you can redistribute it and/or
11    modify it under the terms of the GNU General Public License as
12    published by the Free Software Foundation; either version 2, or (at
13    your option) any later version.
14
15    This program is distributed in the hope that it will be useful, but
16    WITHOUT ANY WARRANTY; without even the implied warranty of
17    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
18    General Public License for more details.
19
20    You should have received a copy of the GNU General Public License
21    along with this program; if not, write to the Free Software
22    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
23    02110-1301, USA.
24
25    $Id: reg.c 7713 2007-04-15 21:49:48Z twisti $
26
27 */
28
29
30 #include "config.h"
31
32 #include <assert.h>
33
34 #include "vm/types.h"
35
36 #include "arch.h"
37 #include "md-abi.h"
38
39 #include "mm/memory.h"
40 #include "vm/jit/abi.h"
41 #include "vm/jit/reg.h"
42
43
44 /* reg_setup *******************************************************************
45
46    TODO
47
48 *******************************************************************************/
49
50 void reg_setup(jitdata *jd)
51 {
52         methodinfo   *m;
53         registerdata *rd;
54         s4            i;
55
56         /* get required compiler data */
57
58         m  = jd->m;
59         rd = jd->rd;
60
61         /* setup the integer register table */
62
63         rd->tmpintregs = DMNEW(s4, INT_TMP_CNT);
64         rd->savintregs = DMNEW(s4, INT_SAV_CNT);
65         rd->freeargintregs = DMNEW(s4, INT_ARG_CNT);
66         rd->freetmpintregs = DMNEW(s4, INT_TMP_CNT);
67         rd->freesavintregs = DMNEW(s4, INT_SAV_CNT);
68
69         rd->argintreguse = 0;
70         rd->tmpintreguse = 0;
71         rd->savintreguse = 0;
72
73         for (i = 0; i < INT_REG_CNT; i++) {
74                 switch (nregdescint[i]) {
75                 case REG_RET:
76                         rd->intreg_ret = i; 
77                         break;
78                 case REG_SAV:
79                         rd->savintregs[rd->savintreguse++] = i;
80                         break;
81                 case REG_TMP:
82                         rd->tmpintregs[rd->tmpintreguse++] = i; 
83                         break;
84                 }
85         }
86         assert(rd->savintreguse == INT_SAV_CNT);
87         assert(rd->tmpintreguse == INT_TMP_CNT);
88
89 #ifdef HAS_ADDRESS_REGISTER_FILE
90         /* setup the address register table */
91
92         rd->argadrregs = DMNEW(s4, ADR_ARG_CNT);
93         rd->tmpadrregs = DMNEW(s4, ADR_TMP_CNT);
94         rd->savadrregs = DMNEW(s4, ADR_SAV_CNT);
95         rd->freeargadrregs = DMNEW(s4, ADR_ARG_CNT);
96         rd->freetmpadrregs = DMNEW(s4, ADR_TMP_CNT);
97         rd->freesavadrregs = DMNEW(s4, ADR_SAV_CNT);
98
99         /*rd->adrreg_argnum = 0; XXX ask twisti */
100         rd->argadrreguse = 0;
101         rd->tmpadrreguse = 0;
102         rd->savadrreguse = 0;
103
104         for (i = 0; i < ADR_REG_CNT; i++) {
105                 switch (nregdescadr[i]) {
106                 case REG_RET:
107                         rd->adrreg_ret = i; 
108                         break;
109                 case REG_SAV:
110                         rd->savadrregs[rd->savadrreguse++] = i;
111                         break;
112                 case REG_TMP:
113                         rd->tmpadrregs[rd->tmpadrreguse++] = i; 
114                         break;
115                 case REG_ARG:
116                         rd->argadrregs[rd->argadrreguse++] = i;
117                         break;
118                 }
119         }
120         assert(rd->savadrreguse == ADR_SAV_CNT);
121         assert(rd->tmpadrreguse == ADR_TMP_CNT);
122         assert(rd->argadrreguse == ADR_ARG_CNT);
123 #endif
124                 
125         /* setup the float register table */
126
127         rd->tmpfltregs = DMNEW(s4, FLT_TMP_CNT);
128         rd->savfltregs = DMNEW(s4, FLT_SAV_CNT);
129         rd->freeargfltregs = DMNEW(s4, FLT_ARG_CNT);
130         rd->freetmpfltregs = DMNEW(s4, FLT_TMP_CNT);
131         rd->freesavfltregs = DMNEW(s4, FLT_SAV_CNT);
132
133         rd->argfltreguse = 0;
134         rd->tmpfltreguse = 0;
135         rd->savfltreguse = 0;
136
137         for (i = 0; i < FLT_REG_CNT; i++) {
138                 switch (nregdescfloat[i]) {
139                 case REG_RET:
140                         rd->fltreg_ret = i;
141                         break;
142                 case REG_SAV:
143                         rd->savfltregs[rd->savfltreguse++] = i;
144                         break;
145                 case REG_TMP:
146                         rd->tmpfltregs[rd->tmpfltreguse++] = i;
147                         break;
148                 }
149         }
150         assert(rd->savfltreguse == FLT_SAV_CNT);
151         assert(rd->tmpfltreguse == FLT_TMP_CNT);
152
153
154         rd->freemem    = DMNEW(s4, m->maxstack);
155 #if defined(HAS_4BYTE_STACKSLOT)
156         rd->freemem_2  = DMNEW(s4, m->maxstack);
157 #endif
158
159 #if defined(SPECIALMEMUSE)
160 # if defined(__DARWIN__)
161         /* 6*4=24 byte linkage area + 8*4=32 byte minimum parameter Area */
162         rd->memuse = LA_SIZE_IN_POINTERS + INT_ARG_CNT; 
163 # else
164         rd->memuse = LA_SIZE_IN_POINTERS;
165 # endif
166 #else
167         rd->memuse = 0; /* init to zero -> analyse_stack will set it to a higher  */
168                         /* value, if appropriate */
169 #endif
170
171         /* Set rd->arg*reguse to *_ARG_CNBT to not use unused argument            */
172         /* registers as temp registers  */
173 #if defined(HAS_ADDRESS_REGISTER_FILE)
174         rd->argadrreguse = 0;
175 #endif /* defined(HAS_ADDRESS_REGISTER_FILE) */
176         rd->argintreguse = 0;
177         rd->argfltreguse = 0;
178 }
179
180
181 /*
182  * These are local overrides for various environment variables in Emacs.
183  * Please do not remove this and leave it at the end of the file, where
184  * Emacs will automagically detect them.
185  * ---------------------------------------------------------------------
186  * Local variables:
187  * mode: c
188  * indent-tabs-mode: t
189  * c-basic-offset: 4
190  * tab-width: 4
191  * End:
192  * vim:noexpandtab:sw=4:ts=4:
193  */