* src/vm/global.h (java_handle_t): Added typedef.
[cacao.git] / src / vm / global.h
1 /* src/vm/global.h - global definitions
2
3    Copyright (C) 1996-2005, 2007, 2006 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: global.h 8295 2007-08-11 17:57:24Z michi $
26
27 */
28
29
30 #ifndef _GLOBAL_H
31 #define _GLOBAL_H
32
33 #include "config.h"
34 #include "vm/types.h"
35
36
37 /* additional data types ******************************************************/
38
39 typedef void *voidptr;                  /* generic pointer                    */
40 typedef void (*functionptr) (void);     /* generic function pointer           */
41 typedef u1* methodptr;
42
43 typedef unsigned int bool;              /* boolean data type                  */
44
45 #define true         1
46 #define false        0
47
48
49 #if defined(ENABLE_SSA)
50 /* immediate to get an addidional target Local Var Index */
51 /* for IINC in Combination with SSA */
52 struct imm {
53         s4 i;
54         s4 op1_t;
55 };
56 #endif
57
58 /* immediate data union */
59
60 typedef union {
61         s4          i;
62         s8          l;
63         float       f;
64         double      d;
65         void       *a;
66         functionptr fp;
67         u1          b[8];
68 #if defined(ENABLE_SSA)
69         struct imm  _i;
70 #endif
71 } imm_union;
72
73
74 /* alignment macros ***********************************************************/
75
76 #define ALIGN_EVEN(a)                   ((a) = (((a) + 1) & ~1))
77 #define ALIGN_ODD(a)                    ((a) =   (a) | 1       )
78
79 #define ALIGN_2(a)                      ALIGN_EVEN(a)
80
81
82 /* forward typedefs ***********************************************************/
83
84 typedef struct java_object_t java_object_t; 
85 typedef struct java_objectarray java_objectarray;
86
87
88 #define MAX_ALIGN 8             /* most generic alignment for JavaVM values   */
89
90
91 /* basic data types ***********************************************************/
92
93 /* The JavaVM types must numbered in the same order as the ICMD_Ixxx
94    to ICMD_Axxx instructions (LOAD and STORE).  All other types can be
95    numbered arbitrarily. */
96
97 #define TYPE_INT     0
98 #define TYPE_LNG     1
99 #define TYPE_FLT     2
100 #define TYPE_DBL     3
101 #define TYPE_ADR     4
102
103 #define TYPE_RET     8   /* must not share bits with TYPE_FLT or TYPE_LNG */
104
105 #define TYPE_VOID    10
106
107
108 #define IS_INT_LNG_TYPE(a)      (!((a) & TYPE_FLT))
109 #define IS_FLT_DBL_TYPE(a)      ((a) & TYPE_FLT)
110 #define IS_2_WORD_TYPE(a)       ((a) & TYPE_LNG)
111
112 #define IS_INT_TYPE(a)          ((a) == TYPE_INT)
113 #define IS_LNG_TYPE(a)          ((a) == TYPE_LNG)
114 #define IS_FLT_TYPE(a)          ((a) == TYPE_FLT)
115 #define IS_DBL_TYPE(a)          ((a) == TYPE_DBL)
116 #define IS_ADR_TYPE(a)          ((a) == TYPE_ADR)
117
118 #define IS_VOID_TYPE(a)         ((a) == TYPE_VOID)
119
120
121 /* some Java related defines **************************************************/
122
123 #define JAVA_VERSION    "1.5.0"         /* this version is supported by CACAO */
124 #define CLASS_VERSION   "50.0"
125
126
127 /* Java class file constants **************************************************/
128
129 #define MAGIC             0xCAFEBABE
130 #define MAJOR_VERSION     50
131 #define MINOR_VERSION     0
132
133
134 /* Constant pool tags *********************************************************/
135
136 #define CONSTANT_Class                 7
137 #define CONSTANT_Fieldref              9
138 #define CONSTANT_Methodref            10
139 #define CONSTANT_InterfaceMethodref   11
140 #define CONSTANT_String                8
141 #define CONSTANT_Integer               3
142 #define CONSTANT_Float                 4
143 #define CONSTANT_Long                  5
144 #define CONSTANT_Double                6
145 #define CONSTANT_NameAndType          12
146 #define CONSTANT_Utf8                  1
147
148 #define CONSTANT_UNUSED                0
149
150
151 /* Class/Field/Method access and property flags *******************************/
152
153 #define ACC_UNDEF               -1      /* used internally                    */
154 #define ACC_NONE                 0      /* used internally                    */
155
156 #define ACC_PUBLIC          0x0001
157 #define ACC_PRIVATE         0x0002
158 #define ACC_PROTECTED       0x0004
159 #define ACC_STATIC          0x0008
160 #define ACC_FINAL           0x0010
161 #define ACC_SUPER           0x0020
162 #define ACC_SYNCHRONIZED    0x0020
163 #define ACC_VOLATILE        0x0040
164 #define ACC_BRIDGE          0x0040
165 #define ACC_TRANSIENT       0x0080
166 #define ACC_VARARGS         0x0080
167 #define ACC_NATIVE          0x0100
168 #define ACC_INTERFACE       0x0200
169 #define ACC_ABSTRACT        0x0400
170 #define ACC_STRICT          0x0800
171 #define ACC_SYNTHETIC       0x1000
172 #define ACC_ANNOTATION      0x2000
173 #define ACC_ENUM            0x4000
174 #define ACC_MIRANDA         0x8000
175
176 /* special flags used in classinfo ********************************************/
177
178 #define ACC_CLASS_REFLECT_MASK      0x0000ffff/* flags reported by reflection */
179
180 #define ACC_CLASS_PRIMITIVE         0x00010000/* class is a primitive class   */
181
182 #define ACC_CLASS_HAS_POINTERS      0x00020000/* instance contains pointers   */
183
184 #define ACC_CLASS_REFERENCE_MASK    0x001c0000
185 #define ACC_CLASS_REFERENCE_SOFT    0x00040000
186 #define ACC_CLASS_REFERENCE_WEAK    0x00080000
187 #define ACC_CLASS_REFERENCE_PHANTOM 0x00100000
188
189
190 /* special flags used in methodinfo *******************************************/
191
192 #define ACC_METHOD_BUILTIN     0x00010000     /* use for descriptor parsing   */
193 #define ACC_METHOD_IMPLEMENTED 0x00020000     /* there is an implementation   */
194 #define ACC_METHOD_MONOMORPHIC 0x00040000     /* currently monomorphic method */
195
196
197 /* data structures of the runtime system **************************************/
198
199 /* java_object_t ***************************************************************
200
201    All objects (and arrays) which resides on the heap need the
202    following header at the beginning of the data structure.
203
204    TODO: Include detailed description from the Wiki (ObjectHeader) here.
205
206 *******************************************************************************/
207
208 #define HDRFLAG_FLC 0x01
209
210 struct java_object_t {                 /* header for all objects              */
211         struct _vftbl            *vftbl;   /* pointer to virtual function table   */
212 #if defined(ENABLE_THREADS)
213         struct lock_record_t *monitorPtr;
214 #endif
215 #if defined(ENABLE_THREADS) || defined(ENABLE_GC_CACAO)
216         ptrint                hdrflags;    /* word containing the FLC and GC bits */
217 #endif
218 };
219
220
221 #if 0
222 typedef struct java_handle_t {
223         java_object_t *heap_object;
224 } java_handle_t;
225 #else
226 typedef java_object_t java_handle_t;
227 #endif
228
229
230 /* arrays **********************************************************************
231
232         All arrays are objects (they need the object header with a pointer
233         to a vftbl (array class table). There is one class for each array
234         type. The array type is described by an arraydescriptor struct
235         which is referenced by the vftbl.
236 */
237
238 typedef struct java_arrayheader {       /* header for all arrays              */
239         java_object_t objheader;            /* object header                      */
240         s4 size;                            /* array size                         */
241 } java_arrayheader;
242
243
244
245 /* structs for all kinds of arrays ********************************************/
246
247 /*  booleanarray and bytearray need identical memory layout (access methods
248     use the same machine code */
249
250 typedef struct java_booleanarray {
251         java_arrayheader header;
252         u1 data[1];
253 } java_booleanarray;
254
255 typedef struct java_bytearray {
256         java_arrayheader header;
257         s1 data[1];
258 } java_bytearray;
259
260 typedef struct java_chararray {
261         java_arrayheader header;
262         u2 data[1];
263 } java_chararray;
264
265 typedef struct java_shortarray {
266         java_arrayheader header;
267         s2 data[1];
268 } java_shortarray;
269
270 typedef struct java_intarray {
271         java_arrayheader header;
272         s4 data[1];
273 } java_intarray;
274
275 typedef struct java_longarray {
276         java_arrayheader header;
277         s8 data[1];
278 } java_longarray;
279
280 typedef struct java_floatarray {
281         java_arrayheader header;
282         float data[1];
283 } java_floatarray;
284
285 typedef struct java_doublearray {
286         java_arrayheader header;
287         double data[1];
288 } java_doublearray;
289
290 /*  objectarray and arrayarray need identical memory layout (access methods
291     use the same machine code */
292
293 struct java_objectarray {
294         java_arrayheader  header;
295         java_object_t    *data[1];
296 };
297
298
299 /* global constants related to the verifier ***********************************/
300
301 /* The verifier needs additional variables in the variable array. Since these */
302 /* must be reserved and set by parse.c and stack.c, we define these numbers   */
303 /* here to avoid mysterious hard-coded constants.                             */
304 /* stack.c needs an extra variable if the verifier is disabled.               */
305
306 #if defined(ENABLE_VERIFIER)
307 #    define VERIFIER_EXTRA_LOCALS  1
308 #    define VERIFIER_EXTRA_VARS    1
309 #    define STACK_EXTRA_VARS       0
310 #else
311 #    define VERIFIER_EXTRA_LOCALS  0
312 #    define VERIFIER_EXTRA_VARS    0
313 #    define STACK_EXTRA_VARS       1
314 #endif
315
316 #endif /* _GLOBAL_H */
317
318
319 /*
320  * These are local overrides for various environment variables in Emacs.
321  * Please do not remove this and leave it at the end of the file, where
322  * Emacs will automagically detect them.
323  * ---------------------------------------------------------------------
324  * Local variables:
325  * mode: c
326  * indent-tabs-mode: t
327  * c-basic-offset: 4
328  * tab-width: 4
329  * End:
330  * vim:noexpandtab:sw=4:ts=4:
331  */