e710e4ac3926a5eb35a64d7c6bcb2d85cced9a04
[cacao.git] / src / vm / jit / powerpc64 / linux / md-asm.h
1 /* src/vm/jit/powerpc64/linux/md-asm.h - assembler defines for PowerPC 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-asm.h 5940 2006-11-09 09:59:28Z tbfg $
32
33 */
34
35
36 #ifndef _MD_ASM_H
37 #define _MD_ASM_H
38
39 #include <asm/ppc_asm.h>
40
41
42 /* register defines ***********************************************************/
43
44 #define zero  r0
45 #define sp    r1
46
47 /* #define XXX   r2  -  system reserved register */
48
49 #define a0    r3
50 #define a1    r4
51 #define a2    r5
52 #define a3    r6
53 #define a4    r7
54 #define a5    r8
55 #define a6    r9
56 #define a7    r10
57
58 #define itmp1 r11
59 #define itmp2 r12
60 #define pv    r14
61
62 #define s0    r15
63
64 #define itmp3 r16
65 #define t0    r17
66 #define t1    r18
67 #define t2    r19
68 #define t3    r20
69 #define t4    r21
70 #define t5    r22
71 #define t6    r23
72
73 #define s1    r24
74 #define s2    r25
75 #define s3    r26
76 #define s4    r27
77 #define s5    r28
78 #define s6    r29
79 #define s7    r30
80 #define s8    r31
81
82 #define v0    a0
83 #define v1    a1
84
85 #define xptr  itmp1
86 #define xpc   itmp2
87
88 #define mptr  r12
89 #define mptrn 12
90
91
92 #define ftmp3 fr0
93
94 #define fa0   fr1
95 #define fa1   fr2
96 #define fa2   fr3
97 #define fa3   fr4
98 #define fa4   fr5
99 #define fa5   fr6
100 #define fa6   fr7
101 #define fa7   fr8
102 #define fa8   fr9
103 #define fa9   fr10
104 #define fa10  fr11
105 #define fa11  fr12
106 #define fa12  fr13
107
108 #define ftmp1 fr14
109 #define ftmp2 fr15
110
111 #define fs0   fr16
112 #define fs1   fr17
113 #define fs2   fr18
114 #define fs3   fr19
115 #define fs4   fr20
116 #define fs5   fr21
117 #define fs6   fr22
118 #define fs7   fr23
119 #define fs8   fr24
120 #define fs9   fr25
121 #define fs10  fr26
122 #define fs11  fr27
123 #define fs12  fr28
124 #define fs13  fr29
125 #define fs14  fr30
126 #define fs15  fr31
127
128 #define fv0   fa0
129
130
131 /* save and restore macros ****************************************************/
132
133 #define SAVE_ARGUMENT_REGISTERS(off) \
134         std     a0,(0+(off))*8(sp); \
135         std     a1,(1+(off))*8(sp); \
136         std     a2,(2+(off))*8(sp); \
137         std     a3,(3+(off))*8(sp); \
138         std     a4,(4+(off))*8(sp); \
139         std     a5,(5+(off))*8(sp); \
140         std     a6,(6+(off))*8(sp); \
141         std     a7,(7+(off))*8(sp); \
142         \
143         stfd    fa0,(8+(off))*8(sp); \
144         stfd    fa1,(9+(off))*8(sp); \
145         stfd    fa2,(10+(off))*8(sp); \
146         stfd    fa3,(11+(off))*8(sp); \
147         stfd    fa4,(12+(off))*8(sp); \
148         stfd    fa5,(13+(off))*8(sp); \
149         stfd    fa6,(14+(off))*8(sp); \
150         stfd    fa7,(15+(off))*8(sp); \
151         stfd    fa8,(16+(off))*8(sp); \
152         stfd    fa9,(17+(off))*8(sp); \
153         stfd    fa10,(18+(off))*8(sp);\
154         stfd    fa11,(19+(off))*8(sp);\
155         stfd    fa12,(20+(off))*8(sp);\
156
157 #define RESTORE_ARGUMENT_REGISTERS(off) \
158         ld     a0,(0+(off))*8(sp); \
159         ld     a1,(1+(off))*8(sp); \
160         ld     a2,(2+(off))*8(sp); \
161         ld     a3,(3+(off))*8(sp); \
162         ld     a4,(4+(off))*8(sp); \
163         ld     a5,(5+(off))*8(sp); \
164         ld     a6,(6+(off))*8(sp); \
165         ld     a7,(7+(off))*8(sp); \
166         \
167         lfd     fa0,(8+(off))*8(sp); \
168         lfd     fa1,(9+(off))*8(sp); \
169         lfd     fa2,(10+(off))*8(sp); \
170         lfd     fa3,(11+(off))*8(sp); \
171         lfd     fa4,(12+(off))*8(sp); \
172         lfd     fa5,(13+(off))*8(sp); \
173         lfd     fa6,(14+(off))*8(sp); \
174         lfd     fa7,(15+(off))*8(sp); \
175         lfd     fa8,(16+(off))*8(sp); \
176         lfd     fa9,(17+(off))*8(sp); \
177         lfd     fa10,(18+(off))*8(sp); \
178         lfd     fa11,(19+(off))*8(sp); \
179         lfd     fa12,(20+(off))*8(sp);
180
181
182 #define SAVE_TEMPORARY_REGISTERS(off) \
183         std     t0,(0+(off))*8(sp); \
184         std     t1,(1+(off))*8(sp); \
185         std     t2,(2+(off))*8(sp); \
186         std     t3,(3+(off))*8(sp); \
187         std     t4,(4+(off))*8(sp); \
188         std     t5,(5+(off))*8(sp); \
189         std     t6,(6+(off))*8(sp); 
190 #if 0   
191         \
192         \
193         stfd    ft0,(7+(off))*8(sp); \
194         stfd    ft1,(8+(off))*8(sp); \
195         stfd    ft2,(9+(off))*8(sp); \
196         stfd    ft3,(10+(off))*8(sp); \
197         stfd    ft4,(11+(off))*8(sp); \
198         stfd    ft5,(12+(off))*8(sp);
199 #endif
200 #define RESTORE_TEMPORARY_REGISTERS(off) \
201         ld     t0,(0+(off))*8(sp); \
202         ld     t1,(1+(off))*8(sp); \
203         ld     t2,(2+(off))*8(sp); \
204         ld     t3,(3+(off))*8(sp); \
205         ld     t4,(4+(off))*8(sp); \
206         ld     t5,(5+(off))*8(sp); \
207         ld     t6,(6+(off))*8(sp); 
208 #if 0   
209         \
210         \
211         lfd     ft0,(7+(off))*8(sp); \
212         lfd     ft1,(8+(off))*8(sp); \
213         lfd     ft2,(9+(off))*8(sp); \
214         lfd     ft3,(10+(off))*8(sp); \
215         lfd     ft4,(11+(off))*8(sp); \
216         lfd     ft5,(12+(off))*8(sp);
217 #endif
218 #endif /* _MD_ASM_H */
219
220
221 /*
222  * These are local overrides for various environment variables in Emacs.
223  * Please do not remove this and leave it at the end of the file, where
224  * Emacs will automagically detect them.
225  * ---------------------------------------------------------------------
226  * Local variables:
227  * mode: c
228  * indent-tabs-mode: t
229  * c-basic-offset: 4
230  * tab-width: 4
231  * End:
232  */