* src/vm/jit/replace.c (replace_find_replacement_point_for_pc): Added assertion.
[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 fa1     %f18
75 #define fa2     %f20
76 #define fa3     %f22
77 #define fa4     %f24
78 #define ft7     %f26
79 #define ft8     %f28
80 #define ft9     %f30
81
82
83 #define bias    2047
84
85
86 /* save and restore macros ****************************************************/
87
88
89 #define SAVE_FLOAT_ARGUMENT_REGISTERS(off) \
90         std     fa0,[%sp + bias + ((0+(off))*8)] ; \
91         std     fa1,[%sp + bias + ((1+(off))*8)] ; \
92         std     fa2,[%sp + bias + ((2+(off))*8)] ; \
93         std     fa3,[%sp + bias + ((3+(off))*8)] ; \
94         std     fa4,[%sp + bias + ((4+(off))*8)] ;
95
96
97 #define RESTORE_FLOAT_ARGUMENT_REGISTERS(off) \
98         ldd     [%sp + bias + ((0+(off))*8)],fa0 ; \
99         ldd     [%sp + bias + ((1+(off))*8)],fa1 ; \
100         ldd     [%sp + bias + ((2+(off))*8)],fa2 ; \
101         ldd     [%sp + bias + ((3+(off))*8)],fa3 ; \
102         ldd     [%sp + bias + ((4+(off))*8)],fa4 ;
103         
104 #define SAVE_FLOAT_TEMPORARY_REGISTERS(off) \
105         std     ft0,[%sp + bias + ((0+(off))*8)] ; \
106         std     ft1,[%sp + bias + ((1+(off))*8)] ; \
107         std     ft2,[%sp + bias + ((2+(off))*8)] ; \
108         std     ft3,[%sp + bias + ((3+(off))*8)] ; \
109         std     ft4,[%sp + bias + ((4+(off))*8)] ; \
110         std     ft5,[%sp + bias + ((5+(off))*8)] ; \
111         std     ft6,[%sp + bias + ((6+(off))*8)] ; \
112         std     ft7,[%sp + bias + ((7+(off))*8)] ; \
113         std     ft8,[%sp + bias + ((8+(off))*8)] ; \
114         std     ft9,[%sp + bias + ((9+(off))*8)] ; \
115
116 #define RESTORE_FLOAT_TEMPORARY_REGISTERS(off) \
117         ldd     [%sp + bias + ((0+(off))*8)],ft0 ; \
118         ldd     [%sp + bias + ((1+(off))*8)],ft1 ; \
119         ldd     [%sp + bias + ((2+(off))*8)],ft2 ; \
120         ldd     [%sp + bias + ((3+(off))*8)],ft3 ; \
121         ldd     [%sp + bias + ((4+(off))*8)],ft4 ; \
122         ldd     [%sp + bias + ((5+(off))*8)],ft5 ; \
123         ldd     [%sp + bias + ((6+(off))*8)],ft6 ; \
124         ldd     [%sp + bias + ((7+(off))*8)],ft7 ; \
125         ldd     [%sp + bias + ((8+(off))*8)],ft8 ; \
126         ldd     [%sp + bias + ((9+(off))*8)],ft9 ; \
127         
128         
129         
130 #endif /* _MD_ASM_H */
131
132
133 /*
134  * These are local overrides for various environment variables in Emacs.
135  * Please do not remove this and leave it at the end of the file, where
136  * Emacs will automagically detect them.
137  *
138  * ---------------------------------------------------------------------
139  * Local variables:
140  * mode: c
141  * indent-tabs-mode: t
142  * c-basic-offset: 4
143  * tab-width: 4
144  * End:
145  */
146