* Removed all Id tags.
[cacao.git] / src / vm / jit / sparc64 / md-asm.h
1 /* src/vm/jit/sparc64/md-asm.h - assembler defines for Sparc 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             Alexander Jordan
29
30    Changes:
31
32 */
33
34 #ifndef _MD_ASM_H
35 #define _MD_ASM_H
36
37
38 /* register defines
39  * ***********************************************************/
40
41 #define zero    %g0
42 #define itmp1   %g1
43 #define itmp2   %g2
44 #define itmp3   %g3
45
46 /* PLT unsafe temp regs */
47 #define temp4 %g4
48 #define temp5 %g5
49
50 #define mptr_itmp2 itmp2
51
52 #define xptr_itmp2 itmp2
53 #define xpc_itmp3  itmp3
54
55 #define ra_caller  %o7
56 #define ra_callee  %i7
57
58 #define pv_caller  %o5
59 #define pv_callee  %i5
60
61
62 #define fv0     %f0
63 #define ft0     %f2
64 #define ft1     %f4
65 #define ft2     %f6
66 #define ft3     %f8
67 #define ft4     %f10
68 #define ft5     %f12
69 #define ft6     %f14
70
71 #define fa0     %f16
72 #define fa0f    %f17
73 #define fa1     %f18
74 #define fa1f    %f19
75 #define fa2     %f20
76 #define fa2f    %f21
77 #define fa3     %f22
78 #define fa3f    %f23
79 #define fa4     %f24
80 #define fa4f    %f25
81 #define ft7     %f26
82 #define ft8     %f28
83 #define ft9     %f30
84
85
86 #define bias    2047
87
88
89 /* save and restore macros ****************************************************/
90
91 #define SAVE_FLOAT_RETURN_REGISTER(off) \
92         std     fv0,[%sp + bias + ((off)*8)] ;
93
94 #define RESTORE_FLOAT_RETURN_REGISTER(off) \
95         ldd     [%sp + bias + ((off)*8)],fv0 ;
96
97
98 #define SAVE_FLOAT_ARGUMENT_REGISTERS(off) \
99         std     fa0,[%sp + bias + ((0+(off))*8)] ; \
100         std     fa1,[%sp + bias + ((1+(off))*8)] ; \
101         std     fa2,[%sp + bias + ((2+(off))*8)] ; \
102         std     fa3,[%sp + bias + ((3+(off))*8)] ; \
103         std     fa4,[%sp + bias + ((4+(off))*8)] ;
104
105
106 #define RESTORE_FLOAT_ARGUMENT_REGISTERS(off) \
107         ldd     [%sp + bias + ((0+(off))*8)],fa0 ; \
108         ldd     [%sp + bias + ((1+(off))*8)],fa1 ; \
109         ldd     [%sp + bias + ((2+(off))*8)],fa2 ; \
110         ldd     [%sp + bias + ((3+(off))*8)],fa3 ; \
111         ldd     [%sp + bias + ((4+(off))*8)],fa4 ;
112         
113 #define SAVE_FLOAT_TEMPORARY_REGISTERS(off) \
114         std     ft0,[%sp + bias + ((0+(off))*8)] ; \
115         std     ft1,[%sp + bias + ((1+(off))*8)] ; \
116         std     ft2,[%sp + bias + ((2+(off))*8)] ; \
117         std     ft3,[%sp + bias + ((3+(off))*8)] ; \
118         std     ft4,[%sp + bias + ((4+(off))*8)] ; \
119         std     ft5,[%sp + bias + ((5+(off))*8)] ; \
120         std     ft6,[%sp + bias + ((6+(off))*8)] ; \
121         std     ft7,[%sp + bias + ((7+(off))*8)] ; \
122         std     ft8,[%sp + bias + ((8+(off))*8)] ; \
123         std     ft9,[%sp + bias + ((9+(off))*8)] ; \
124
125 #define RESTORE_FLOAT_TEMPORARY_REGISTERS(off) \
126         ldd     [%sp + bias + ((0+(off))*8)],ft0 ; \
127         ldd     [%sp + bias + ((1+(off))*8)],ft1 ; \
128         ldd     [%sp + bias + ((2+(off))*8)],ft2 ; \
129         ldd     [%sp + bias + ((3+(off))*8)],ft3 ; \
130         ldd     [%sp + bias + ((4+(off))*8)],ft4 ; \
131         ldd     [%sp + bias + ((5+(off))*8)],ft5 ; \
132         ldd     [%sp + bias + ((6+(off))*8)],ft6 ; \
133         ldd     [%sp + bias + ((7+(off))*8)],ft7 ; \
134         ldd     [%sp + bias + ((8+(off))*8)],ft8 ; \
135         ldd     [%sp + bias + ((9+(off))*8)],ft9 ; \
136         
137         
138         
139 #endif /* _MD_ASM_H */
140
141
142 /*
143  * These are local overrides for various environment variables in Emacs.
144  * Please do not remove this and leave it at the end of the file, where
145  * Emacs will automagically detect them.
146  *
147  * ---------------------------------------------------------------------
148  * Local variables:
149  * mode: c
150  * indent-tabs-mode: t
151  * c-basic-offset: 4
152  * tab-width: 4
153  * End:
154  */
155