~jderose/ubuntu/raring/qemu/vde-again

« back to all changes in this revision

Viewing changes to dyngen-exec.h

Tags: upstream-0.9.0+20070816
ImportĀ upstreamĀ versionĀ 0.9.0+20070816

Show diffs side-by-side

added added

removed removed

Lines of Context:
78
78
#define UINT32_MAX              (4294967295U)
79
79
#define UINT64_MAX              ((uint64_t)(18446744073709551615))
80
80
 
 
81
#ifdef _BSD
 
82
typedef struct __sFILE FILE;
 
83
#else
81
84
typedef struct FILE FILE;
 
85
#endif
82
86
extern int fprintf(FILE *, const char *, ...);
 
87
extern int fputs(const char *, FILE *);
83
88
extern int printf(const char *, ...);
84
89
#undef NULL
85
90
#define NULL 0
86
91
 
87
 
#ifdef __i386__
 
92
#if defined(__i386__)
88
93
#define AREG0 "ebp"
89
94
#define AREG1 "ebx"
90
95
#define AREG2 "esi"
91
96
#define AREG3 "edi"
92
 
#endif
93
 
#ifdef __x86_64__
94
 
#define AREG0 "rbp"
95
 
#define AREG1 "rbx"
 
97
#elif defined(__x86_64__)
 
98
#define AREG0 "r14"
 
99
#define AREG1 "r15"
96
100
#define AREG2 "r12"
97
101
#define AREG3 "r13"
98
 
//#define AREG4 "r14"
99
 
//#define AREG5 "r15"
100
 
#endif
101
 
#ifdef __powerpc__
 
102
//#define AREG4 "rbp"
 
103
//#define AREG5 "rbx"
 
104
#elif defined(__powerpc__)
102
105
#define AREG0 "r27"
103
106
#define AREG1 "r24"
104
107
#define AREG2 "r25"
116
119
#endif
117
120
#define USE_INT_TO_FLOAT_HELPERS
118
121
#define BUGGY_GCC_DIV64
119
 
#endif
120
 
#ifdef __arm__
 
122
#elif defined(__arm__)
121
123
#define AREG0 "r7"
122
124
#define AREG1 "r4"
123
125
#define AREG2 "r5"
124
126
#define AREG3 "r6"
125
 
#endif
126
 
#ifdef __mips__
127
 
#define AREG0 "s3"
 
127
#elif defined(__mips__)
 
128
#define AREG0 "fp"
128
129
#define AREG1 "s0"
129
130
#define AREG2 "s1"
130
131
#define AREG3 "s2"
131
 
#endif
132
 
#ifdef __sparc__
 
132
#define AREG4 "s3"
 
133
#define AREG5 "s4"
 
134
#define AREG6 "s5"
 
135
#define AREG7 "s6"
 
136
#define AREG8 "s7"
 
137
#elif defined(__sparc__)
133
138
#ifdef HOST_SOLARIS
134
139
#define AREG0 "g2"
135
140
#define AREG1 "g3"
158
163
#endif
159
164
#endif
160
165
#define USE_FP_CONVERT
161
 
#endif
162
 
#ifdef __s390__
 
166
#elif defined(__s390__)
163
167
#define AREG0 "r10"
164
168
#define AREG1 "r7"
165
169
#define AREG2 "r8"
166
170
#define AREG3 "r9"
167
 
#endif
168
 
#ifdef __alpha__
 
171
#elif defined(__alpha__)
169
172
/* Note $15 is the frame pointer, so anything in op-i386.c that would
170
173
   require a frame pointer, like alloca, would probably loose.  */
171
174
#define AREG0 "$15"
175
178
#define AREG4 "$12"
176
179
#define AREG5 "$13"
177
180
#define AREG6 "$14"
178
 
#endif
179
 
#ifdef __mc68000
 
181
#elif defined(__mc68000)
180
182
#define AREG0 "%a5"
181
183
#define AREG1 "%a4"
182
184
#define AREG2 "%d7"
183
185
#define AREG3 "%d6"
184
186
#define AREG4 "%d5"
185
 
#endif
186
 
#ifdef __ia64__
 
187
#elif defined(__ia64__)
187
188
#define AREG0 "r7"
188
189
#define AREG1 "r4"
189
190
#define AREG2 "r5"
190
191
#define AREG3 "r6"
 
192
#else
 
193
#error unsupported CPU
191
194
#endif
192
195
 
193
196
/* force GCC to generate only one epilog at the end of the function */
240
243
#define ASM_NAME(x) #x
241
244
#endif
242
245
 
243
 
#ifdef __i386__
244
 
#define EXIT_TB() asm volatile ("ret")
245
 
#define GOTO_LABEL_PARAM(n) asm volatile ("jmp " ASM_NAME(__op_gen_label) #n)
246
 
#endif
247
 
#ifdef __x86_64__
248
 
#define EXIT_TB() asm volatile ("ret")
249
 
#define GOTO_LABEL_PARAM(n) asm volatile ("jmp " ASM_NAME(__op_gen_label) #n)
250
 
#endif
251
 
#ifdef __powerpc__
 
246
#if defined(__i386__)
 
247
#define EXIT_TB() asm volatile ("ret")
 
248
#define GOTO_LABEL_PARAM(n) asm volatile ("jmp " ASM_NAME(__op_gen_label) #n)
 
249
#elif defined(__x86_64__)
 
250
#define EXIT_TB() asm volatile ("ret")
 
251
#define GOTO_LABEL_PARAM(n) asm volatile ("jmp " ASM_NAME(__op_gen_label) #n)
 
252
#elif defined(__powerpc__)
252
253
#define EXIT_TB() asm volatile ("blr")
253
254
#define GOTO_LABEL_PARAM(n) asm volatile ("b " ASM_NAME(__op_gen_label) #n)
254
 
#endif
255
 
#ifdef __s390__
 
255
#elif defined(__s390__)
256
256
#define EXIT_TB() asm volatile ("br %r14")
257
 
#define GOTO_LABEL_PARAM(n) asm volatile ("b " ASM_NAME(__op_gen_label) #n)
258
 
#endif
259
 
#ifdef __alpha__
 
257
#define GOTO_LABEL_PARAM(n) asm volatile ("bras %r7,8; .long " ASM_NAME(__op_gen_label) #n "; l %r7, 0(%r7); br %r7")
 
258
#elif defined(__alpha__)
260
259
#define EXIT_TB() asm volatile ("ret")
261
 
#endif
262
 
#ifdef __ia64__
 
260
#elif defined(__ia64__)
263
261
#define EXIT_TB() asm volatile ("br.ret.sptk.many b0;;")
264
262
#define GOTO_LABEL_PARAM(n) asm volatile ("br.sptk.many " \
265
263
                                          ASM_NAME(__op_gen_label) #n)
266
 
#endif
267
 
#ifdef __sparc__
 
264
#elif defined(__sparc__)
268
265
#define EXIT_TB() asm volatile ("jmpl %i0 + 8, %g0; nop")
269
266
#define GOTO_LABEL_PARAM(n) asm volatile ("ba " ASM_NAME(__op_gen_label) #n ";nop")
270
 
#endif
271
 
#ifdef __arm__
 
267
#elif defined(__arm__)
272
268
#define EXIT_TB() asm volatile ("b exec_loop")
273
269
#define GOTO_LABEL_PARAM(n) asm volatile ("b " ASM_NAME(__op_gen_label) #n)
274
 
#endif
275
 
#ifdef __mc68000
 
270
#elif defined(__mc68000)
276
271
#define EXIT_TB() asm volatile ("rts")
 
272
#elif defined(__mips__)
 
273
#define EXIT_TB() asm volatile ("jr $ra")
 
274
#define GOTO_LABEL_PARAM(n) asm volatile (".set noat; la $1, " ASM_NAME(__op_gen_label) #n "; jr $1; .set at")
 
275
#else
 
276
#error unsupported CPU
277
277
#endif
278
278
 
279
279
#endif /* !defined(__DYNGEN_EXEC_H__) */