* src/vm/jit/s390/emit.c,
[cacao.git] / src / vm / jit / s390 / md-abi.h
1 /* src/vm/jit/x86_64/md-abi.h - defines for x86_64 Linux ABI
2
3    Copyright (C) 1996-2005, 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    Contact: cacao@cacaojvm.org
26
27    Authors: Christian Thalinger
28
29    Changes:
30
31    $Id: md-abi.h 7680 2007-04-10 05:02:20Z pm $
32
33 */
34
35
36 #ifndef _MD_ABI_H
37 #define _MD_ABI_H
38
39 /* keep old code happy */
40
41 #define RIP    -1
42 #define RAX    0
43 #define RCX    1
44 #define RDX    2
45 #define RBX    3
46 #define RSP    4
47 #define RBP    5
48 #define RSI    6
49 #define RDI    7
50 #define R8     8
51 #define R9     9
52 #define R10    10
53 #define R11    11
54 #define R12    12
55 #define R13    13
56 #define R14    14
57 #define R15    15
58
59
60 #define XMM0   0
61 #define XMM1   1
62 #define XMM2   2
63 #define XMM3   3
64 #define XMM4   4
65 #define XMM5   5
66 #define XMM6   6
67 #define XMM7   7
68 #define XMM8   8
69 #define XMM9   9
70 #define XMM10  10
71 #define XMM11  11
72 #define XMM12  12
73 #define XMM13  13
74 #define XMM14  14
75 #define XMM15  15
76
77
78
79 /* define registers ***********************************************************/
80
81 #define R0     0
82 #define R1     1
83 #define R2     2
84 #define R3     3
85 #define R4     4
86 #define R5     5
87 #define R6     6 
88 #define R7     7
89 #define R8     8
90 #define R9     9
91 #define R10    10
92 #define R11    11
93 #define R12    12
94 #define R13    13
95 #define R14    14
96 #define R15    15
97
98 #define F0     0
99 #define F1     1
100 #define F2     2
101 #define F3     3
102 #define F4     4
103 #define F5     5
104 #define F6     6
105 #define F7     7
106 #define F8     8
107 #define F9     9
108 #define F10    10
109 #define F11    11
110 #define F12    12
111 #define F13    13
112 #define F14    14
113 #define F15    15
114
115 /* preallocated registers *****************************************************/
116
117 /* integer registers */
118   
119 #define REG_RESULT      R2       /* to deliver method results                 */
120 #define REG_RESULT2     R3
121
122 #define REG_ITMP1       R1      /* temporary register                        */
123 #define REG_ITMP2       R12     /* temporary register and method pointer     */
124 #define REG_ITMP3       R14     /* temporary register                        */
125
126 #define IS_REG_ITMP(x) (((x) == REG_ITMP1) || ((x) == REG_ITMP2) || ((x) == REG_ITMP3))
127
128 #define REG_ITMP12_PACKED    PACK_REGS(REG_ITMP2, REG_ITMP1)
129 #define REG_ITMP23_PACKED    PACK_REGS(REG_ITMP3, REG_ITMP2)
130 #define REG_RESULT_PACKED    PACK_REGS(REG_RESULT2, REG_RESULT)
131
132 #define REG_METHODPTR   REG_ITMP2/* pointer to the place from where the       */
133                                  /* procedure vector has been fetched         */
134
135 #define REG_NULL        -1       /* used for reg_of_var where d is not needed */
136
137 #define REG_ITMP1_XPTR  REG_ITMP1/* exception pointer = temporary register 1  */
138 #define REG_ITMP2_XPC   REG_ITMP2/* exception pc = temporary register 2       */
139
140 #define REG_SP          R15      /* stack pointer                             */
141 #define REG_RA          R14      /* same as itmp3 */
142
143 #define REG_PV  R13
144
145 #define REG_A0          R2      /* define some argument registers            */
146 #define REG_A1          R3
147 #define REG_A2          R4 
148 #define REG_A3          R5
149 #define REG_A4          R6
150
151 #define REG_FA0         F0
152 #define REG_FA1         F2
153
154 /* floating point registers */
155
156 #define REG_FRESULT     F0       /* to deliver floating point method results  */
157
158 #define REG_FTMP1       F4       /* temporary floating point register         */
159 #define REG_FTMP2       F6       /* temporary floating point register         */
160 /* No ftmp3 */
161 /* #define REG_FTMP3       F5 */       /* temporary floating point register         */
162
163
164 #define INT_REG_CNT     16       /* number of integer registers               */
165 #define INT_SAV_CNT     5        /* number of integer callee saved registers  */
166 #define INT_ARG_CNT     5        /* number of integer argument registers      */
167 #define INT_TMP_CNT     1        /* number of integer temporary registers     */
168 #define INT_RES_CNT     5        /* number of integer reserved registers      */
169
170 #define FLT_REG_CNT     16       /* number of float registers                 */
171 #define FLT_SAV_CNT     0        /* number of float callee saved registers    */
172 #define FLT_ARG_CNT     2        /* number of float argument registers        */
173 #define FLT_TMP_CNT     12        /* number of float temporary registers       */
174 #define FLT_RES_CNT     2        /* number of float reserved registers        */
175
176 #define TRACE_ARGS_NUM  8
177
178
179
180
181
182
183
184
185
186
187
188
189 #endif /* _MD_ABI_H */
190
191
192 /*
193  * These are local overrides for various environment variables in Emacs.
194  * Please do not remove this and leave it at the end of the file, where
195  * Emacs will automagically detect them.
196  * ---------------------------------------------------------------------
197  * Local variables:
198  * mode: c
199  * indent-tabs-mode: t
200  * c-basic-offset: 4
201  * tab-width: 4
202  * End:
203  */