* Removed all Id tags.
[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 */
26
27
28 #include "config.h"
29
30 #include <assert.h>
31
32 #include "vm/types.h"
33
34 #include "arch.h"
35 #include "md-abi.h"
36
37 #include "mm/memory.h"
38 #include "vm/jit/abi.h"
39 #include "vm/jit/reg.h"
40
41
42 /* reg_setup *******************************************************************
43
44    TODO
45
46 *******************************************************************************/
47
48 void reg_setup(jitdata *jd)
49 {
50         methodinfo   *m;
51         registerdata *rd;
52         s4            i;
53
54         /* get required compiler data */
55
56         m  = jd->m;
57         rd = jd->rd;
58
59         /* setup the integer register table */
60
61         rd->tmpintregs = DMNEW(s4, INT_TMP_CNT);
62         rd->savintregs = DMNEW(s4, INT_SAV_CNT);
63         rd->freeargintregs = DMNEW(s4, INT_ARG_CNT);
64         rd->freetmpintregs = DMNEW(s4, INT_TMP_CNT);
65         rd->freesavintregs = DMNEW(s4, INT_SAV_CNT);
66
67         rd->argintreguse = 0;
68         rd->tmpintreguse = 0;
69         rd->savintreguse = 0;
70
71         for (i = 0; i < INT_REG_CNT; i++) {
72                 switch (nregdescint[i]) {
73                 case REG_RET:
74                         rd->intreg_ret = i; 
75                         break;
76                 case REG_SAV:
77                         rd->savintregs[rd->savintreguse++] = i;
78                         break;
79                 case REG_TMP:
80                         rd->tmpintregs[rd->tmpintreguse++] = i; 
81                         break;
82                 }
83         }
84         assert(rd->savintreguse == INT_SAV_CNT);
85         assert(rd->tmpintreguse == INT_TMP_CNT);
86
87 #ifdef HAS_ADDRESS_REGISTER_FILE
88         /* setup the address register table */
89
90         rd->argadrregs = DMNEW(s4, ADR_ARG_CNT);
91         rd->tmpadrregs = DMNEW(s4, ADR_TMP_CNT);
92         rd->savadrregs = DMNEW(s4, ADR_SAV_CNT);
93         rd->freeargadrregs = DMNEW(s4, ADR_ARG_CNT);
94         rd->freetmpadrregs = DMNEW(s4, ADR_TMP_CNT);
95         rd->freesavadrregs = DMNEW(s4, ADR_SAV_CNT);
96
97         /*rd->adrreg_argnum = 0; XXX ask twisti */
98         rd->argadrreguse = 0;
99         rd->tmpadrreguse = 0;
100         rd->savadrreguse = 0;
101
102         for (i = 0; i < ADR_REG_CNT; i++) {
103                 switch (nregdescadr[i]) {
104                 case REG_RET:
105                         rd->adrreg_ret = i; 
106                         break;
107                 case REG_SAV:
108                         rd->savadrregs[rd->savadrreguse++] = i;
109                         break;
110                 case REG_TMP:
111                         rd->tmpadrregs[rd->tmpadrreguse++] = i; 
112                         break;
113                 case REG_ARG:
114                         rd->argadrregs[rd->argadrreguse++] = i;
115                         break;
116                 }
117         }
118         assert(rd->savadrreguse == ADR_SAV_CNT);
119         assert(rd->tmpadrreguse == ADR_TMP_CNT);
120         assert(rd->argadrreguse == ADR_ARG_CNT);
121 #endif
122                 
123         /* setup the float register table */
124
125         rd->tmpfltregs = DMNEW(s4, FLT_TMP_CNT);
126         rd->savfltregs = DMNEW(s4, FLT_SAV_CNT);
127         rd->freeargfltregs = DMNEW(s4, FLT_ARG_CNT);
128         rd->freetmpfltregs = DMNEW(s4, FLT_TMP_CNT);
129         rd->freesavfltregs = DMNEW(s4, FLT_SAV_CNT);
130
131         rd->argfltreguse = 0;
132         rd->tmpfltreguse = 0;
133         rd->savfltreguse = 0;
134
135         for (i = 0; i < FLT_REG_CNT; i++) {
136                 switch (nregdescfloat[i]) {
137                 case REG_RET:
138                         rd->fltreg_ret = i;
139                         break;
140                 case REG_SAV:
141                         rd->savfltregs[rd->savfltreguse++] = i;
142                         break;
143                 case REG_TMP:
144                         rd->tmpfltregs[rd->tmpfltreguse++] = i;
145                         break;
146                 }
147         }
148         assert(rd->savfltreguse == FLT_SAV_CNT);
149         assert(rd->tmpfltreguse == FLT_TMP_CNT);
150
151
152         rd->freemem    = DMNEW(s4, m->maxstack);
153 #if defined(HAS_4BYTE_STACKSLOT)
154         rd->freemem_2  = DMNEW(s4, m->maxstack);
155 #endif
156
157 #if defined(SPECIALMEMUSE)
158 # if defined(__DARWIN__)
159         /* 6*4=24 byte linkage area + 8*4=32 byte minimum parameter Area */
160         rd->memuse = LA_SIZE_IN_POINTERS + INT_ARG_CNT; 
161 # else
162         rd->memuse = LA_SIZE_IN_POINTERS;
163 # endif
164 #else
165         rd->memuse = 0; /* init to zero -> analyse_stack will set it to a higher  */
166                         /* value, if appropriate */
167 #endif
168
169         /* Set rd->arg*reguse to *_ARG_CNBT to not use unused argument            */
170         /* registers as temp registers  */
171 #if defined(HAS_ADDRESS_REGISTER_FILE)
172         rd->argadrreguse = 0;
173 #endif /* defined(HAS_ADDRESS_REGISTER_FILE) */
174         rd->argintreguse = 0;
175         rd->argfltreguse = 0;
176 }
177
178
179 /*
180  * These are local overrides for various environment variables in Emacs.
181  * Please do not remove this and leave it at the end of the file, where
182  * Emacs will automagically detect them.
183  * ---------------------------------------------------------------------
184  * Local variables:
185  * mode: c
186  * indent-tabs-mode: t
187  * c-basic-offset: 4
188  * tab-width: 4
189  * End:
190  * vim:noexpandtab:sw=4:ts=4:
191  */