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