Machine dependent stuff.
[cacao.git] / src / vm / jit / powerpc / linux / md-asm.h
1 /* src/vm/jit/powerpc/linux/md-asm.h - assembler defines for PowerPC Linux ABI
2
3    Copyright (C) 1996-2005 R. Grafl, A. Krall, C. Kruegel, C. Oates,
4    R. Obermaisser, M. Platter, M. Probst, S. Ring, E. Steiner,
5    C. Thalinger, D. Thuernbeck, P. Tomsich, C. Ullrich, J. Wenninger,
6    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., 59 Temple Place - Suite 330, Boston, MA
23    02111-1307, USA.
24
25    Contact: cacao@complang.tuwien.ac.at
26
27    Authors: Christian Thalinger
28
29    Changes:
30
31    $Id: md-asm.h 2539 2005-05-31 15:55:54Z twisti $
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 sp    r1
45
46 #define a0    r3
47 #define a1    r4
48 #define a2    r5
49 #define a3    r6
50 #define a4    r7
51 #define a5    r8
52 #define a6    r9
53 #define a7    r10
54
55 #define pv    r13
56
57 #define s0    r14
58 #define s1    r15
59
60 #define t0    r16
61 #define t1    r17
62 #define t2    r18
63 #define t3    r19
64 #define t4    r20
65 #define t5    r21
66 #define t6    r22
67 #define t7    r23
68
69 #define s2    r24
70 #define s3    r25
71 #define s4    r26
72 #define s5    r27
73 #define s6    r28
74 #define s7    r29
75 #define s8    r30
76 #define s9    r31
77
78 #define v0    a0
79 #define v1    a1
80
81 #define itmp1 r11
82 #define itmp2 r12
83 #define itmp3 r0
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
103 #define fa8   fr9
104 #define fa9   fr10
105 #define fa10  fr11
106 #define fa11  fr12
107 #define fa12  fr13
108
109 #define fs0   fr14
110 #define fs1   fr15
111
112 #define ftmp1 fr16
113 #define ftmp2 fr17
114
115 #define ft0   fr18
116 #define ft1   fr19
117 #define ft2   fr20
118 #define ft3   fr21
119 #define ft4   fr22
120 #define ft5   fr23
121
122 #define fs2   fr24
123 #define fs3   fr25
124 #define fs4   fr26
125 #define fs5   fr27
126 #define fs6   fr28
127 #define fs7   fr29
128 #define fs8   fr30
129 #define fs9   fr31
130
131 #define fv0   fa0
132
133
134 /* save and restore macros ****************************************************/
135
136 #define SAVE_ARGUMENT_REGISTERS(off) \
137         stw     a0,(0+(off))*4(sp); \
138         stw     a1,(1+(off))*4(sp); \
139         stw     a2,(2+(off))*4(sp); \
140         stw     a3,(3+(off))*4(sp); \
141         stw     a4,(4+(off))*4(sp); \
142         stw     a5,(5+(off))*4(sp); \
143         stw     a6,(6+(off))*4(sp); \
144         stw     a7,(7+(off))*4(sp); \
145         \
146         stfd    fa0,(8+(off))*4)(sp); \
147         stfd    fa1,(10+(off))*4)(sp); \
148         stfd    fa2,(12+(off))*4)(sp); \
149         stfd    fa3,(14+(off))*4)(sp); \
150         stfd    fa4,(16+(off))*4)(sp); \
151         stfd    fa5,(18+(off))*4)(sp); \
152         stfd    fa6,(20+(off))*4)(sp); \
153         stfd    fa7,(22+(off))*4)(sp);
154
155 #define RESTORE_ARGUMENT_REGISTERS(off) \
156         lwz     a0,(0+(off))*4(sp); \
157         lwz     a1,(1+(off))*4(sp); \
158         lwz     a2,(2+(off))*4(sp); \
159         lwz     a3,(3+(off))*4(sp); \
160         lwz     a4,(4+(off))*4(sp); \
161         lwz     a5,(5+(off))*4(sp); \
162         lwz     a6,(6+(off))*4(sp); \
163         lwz     a7,(7+(off))*4(sp); \
164         \
165         lfd     fa0,(8+(off))*4)(sp); \
166         lfd     fa1,(10+(off))*4)(sp); \
167         lfd     fa2,(12+(off))*4)(sp); \
168         lfd     fa3,(14+(off))*4)(sp); \
169         lfd     fa4,(16+(off))*4)(sp); \
170         lfd     fa5,(18+(off))*4)(sp); \
171         lfd     fa6,(20+(off))*4)(sp); \
172         lfd     fa7,(22+(off))*4)(sp);
173
174
175 #define SAVE_TEMPORARY_REGISTERS(off) \
176         stw     t0,(0+(off))*4(sp); \
177         stw     t1,(1+(off))*4(sp); \
178         stw     t2,(2+(off))*4(sp); \
179         stw     t3,(3+(off))*4(sp); \
180         stw     t4,(4+(off))*4(sp); \
181         stw     t5,(5+(off))*4(sp); \
182         stw     t6,(6+(off))*4(sp); \
183         stw     t7,(7+(off))*4(sp); \
184         \
185         stfd    ft0,(8+(off))*4)(sp); \
186         stfd    ft1,(10+(off))*4)(sp); \
187         stfd    ft2,(12+(off))*4)(sp); \
188         stfd    ft3,(14+(off))*4)(sp); \
189         stfd    ft4,(16+(off))*4)(sp); \
190         stfd    ft5,(18+(off))*4)(sp);
191
192 #define RESTORE_TEMPORARY_REGISTERS(off) \
193         lwz     t0,(0+(off))*4(sp); \
194         lwz     t1,(1+(off))*4(sp); \
195         lwz     t2,(2+(off))*4(sp); \
196         lwz     t3,(3+(off))*4(sp); \
197         lwz     t4,(4+(off))*4(sp); \
198         lwz     t5,(5+(off))*4(sp); \
199         lwz     t6,(6+(off))*4(sp); \
200         lwz     t7,(7+(off))*4(sp); \
201         \
202         lfd     ft0,(8+(off))*4)(sp); \
203         lfd     ft1,(10+(off))*4)(sp); \
204         lfd     ft2,(12+(off))*4)(sp); \
205         lfd     ft3,(14+(off))*4)(sp); \
206         lfd     ft4,(16+(off))*4)(sp); \
207         lfd     ft5,(18+(off))*4)(sp);
208
209 #endif /* _MD_ASM_H */
210
211
212 /*
213  * These are local overrides for various environment variables in Emacs.
214  * Please do not remove this and leave it at the end of the file, where
215  * Emacs will automagically detect them.
216  * ---------------------------------------------------------------------
217  * Local variables:
218  * mode: c
219  * indent-tabs-mode: t
220  * c-basic-offset: 4
221  * tab-width: 4
222  * End:
223  */