171 |
171 |
void helper_lsl(void);
|
172 |
172 |
void helper_lar(void);
|
173 |
173 |
|
|
174 |
/* XXX: move that to a generic header */
|
|
175 |
#if !defined(CONFIG_USER_ONLY)
|
|
176 |
|
|
177 |
#define ldul_user ldl_user
|
|
178 |
#define ldul_kernel ldl_kernel
|
|
179 |
|
|
180 |
#define ACCESS_TYPE 0
|
|
181 |
#define MEMSUFFIX _kernel
|
|
182 |
#define DATA_SIZE 1
|
|
183 |
#include "softmmu_header.h"
|
|
184 |
|
|
185 |
#define DATA_SIZE 2
|
|
186 |
#include "softmmu_header.h"
|
|
187 |
|
|
188 |
#define DATA_SIZE 4
|
|
189 |
#include "softmmu_header.h"
|
|
190 |
|
|
191 |
#define DATA_SIZE 8
|
|
192 |
#include "softmmu_header.h"
|
|
193 |
#undef ACCESS_TYPE
|
|
194 |
#undef MEMSUFFIX
|
|
195 |
|
|
196 |
#define ACCESS_TYPE 1
|
|
197 |
#define MEMSUFFIX _user
|
|
198 |
#define DATA_SIZE 1
|
|
199 |
#include "softmmu_header.h"
|
|
200 |
|
|
201 |
#define DATA_SIZE 2
|
|
202 |
#include "softmmu_header.h"
|
|
203 |
|
|
204 |
#define DATA_SIZE 4
|
|
205 |
#include "softmmu_header.h"
|
|
206 |
|
|
207 |
#define DATA_SIZE 8
|
|
208 |
#include "softmmu_header.h"
|
|
209 |
#undef ACCESS_TYPE
|
|
210 |
#undef MEMSUFFIX
|
|
211 |
|
|
212 |
/* these access are slower, they must be as rare as possible */
|
|
213 |
#define ACCESS_TYPE 2
|
|
214 |
#define MEMSUFFIX _data
|
|
215 |
#define DATA_SIZE 1
|
|
216 |
#include "softmmu_header.h"
|
|
217 |
|
|
218 |
#define DATA_SIZE 2
|
|
219 |
#include "softmmu_header.h"
|
|
220 |
|
|
221 |
#define DATA_SIZE 4
|
|
222 |
#include "softmmu_header.h"
|
|
223 |
|
|
224 |
#define DATA_SIZE 8
|
|
225 |
#include "softmmu_header.h"
|
|
226 |
#undef ACCESS_TYPE
|
|
227 |
#undef MEMSUFFIX
|
|
228 |
|
|
229 |
#define ldub(p) ldub_data(p)
|
|
230 |
#define ldsb(p) ldsb_data(p)
|
|
231 |
#define lduw(p) lduw_data(p)
|
|
232 |
#define ldsw(p) ldsw_data(p)
|
|
233 |
#define ldl(p) ldl_data(p)
|
|
234 |
#define ldq(p) ldq_data(p)
|
|
235 |
|
|
236 |
#define stb(p, v) stb_data(p, v)
|
|
237 |
#define stw(p, v) stw_data(p, v)
|
|
238 |
#define stl(p, v) stl_data(p, v)
|
|
239 |
#define stq(p, v) stq_data(p, v)
|
|
240 |
|
|
241 |
static inline double ldfq(void *ptr)
|
|
242 |
{
|
|
243 |
union {
|
|
244 |
double d;
|
|
245 |
uint64_t i;
|
|
246 |
} u;
|
|
247 |
u.i = ldq(ptr);
|
|
248 |
return u.d;
|
|
249 |
}
|
|
250 |
|
|
251 |
static inline void stfq(void *ptr, double v)
|
|
252 |
{
|
|
253 |
union {
|
|
254 |
double d;
|
|
255 |
uint64_t i;
|
|
256 |
} u;
|
|
257 |
u.d = v;
|
|
258 |
stq(ptr, u.i);
|
|
259 |
}
|
|
260 |
|
|
261 |
static inline float ldfl(void *ptr)
|
|
262 |
{
|
|
263 |
union {
|
|
264 |
float f;
|
|
265 |
uint32_t i;
|
|
266 |
} u;
|
|
267 |
u.i = ldl(ptr);
|
|
268 |
return u.f;
|
|
269 |
}
|
|
270 |
|
|
271 |
static inline void stfl(void *ptr, float v)
|
|
272 |
{
|
|
273 |
union {
|
|
274 |
float f;
|
|
275 |
uint32_t i;
|
|
276 |
} u;
|
|
277 |
u.f = v;
|
|
278 |
stl(ptr, u.i);
|
|
279 |
}
|
|
280 |
|
|
281 |
#endif /* !defined(CONFIG_USER_ONLY) */
|
|
282 |
|
174 |
283 |
#ifdef USE_X86LDOUBLE
|
175 |
284 |
/* use long double functions */
|
176 |
285 |
#define lrint lrintl
|
... | ... | |
317 |
426 |
e |= SIGND(temp) >> 16;
|
318 |
427 |
stw(ptr + 8, e);
|
319 |
428 |
}
|
320 |
|
#endif
|
|
429 |
#else
|
|
430 |
|
|
431 |
/* XXX: same endianness assumed */
|
|
432 |
|
|
433 |
#ifdef CONFIG_USER_ONLY
|
|
434 |
|
|
435 |
static inline CPU86_LDouble helper_fldt(uint8_t *ptr)
|
|
436 |
{
|
|
437 |
return *(CPU86_LDouble *)ptr;
|
|
438 |
}
|
|
439 |
|
|
440 |
static inline void helper_fstt(CPU86_LDouble f, uint8_t *ptr)
|
|
441 |
{
|
|
442 |
*(CPU86_LDouble *)ptr = f;
|
|
443 |
}
|
|
444 |
|
|
445 |
#else
|
|
446 |
|
|
447 |
/* we use memory access macros */
|
|
448 |
|
|
449 |
static inline CPU86_LDouble helper_fldt(uint8_t *ptr)
|
|
450 |
{
|
|
451 |
CPU86_LDoubleU temp;
|
|
452 |
|
|
453 |
temp.l.lower = ldq(ptr);
|
|
454 |
temp.l.upper = lduw(ptr + 8);
|
|
455 |
return temp.d;
|
|
456 |
}
|
|
457 |
|
|
458 |
static inline void helper_fstt(CPU86_LDouble f, uint8_t *ptr)
|
|
459 |
{
|
|
460 |
CPU86_LDoubleU temp;
|
|
461 |
|
|
462 |
temp.d = f;
|
|
463 |
stq(ptr, temp.l.lower);
|
|
464 |
stw(ptr + 8, temp.l.upper);
|
|
465 |
}
|
|
466 |
|
|
467 |
#endif /* !CONFIG_USER_ONLY */
|
|
468 |
|
|
469 |
#endif /* USE_X86LDOUBLE */
|
321 |
470 |
|
322 |
471 |
const CPU86_LDouble f15rk[7];
|
323 |
472 |
|
... | ... | |
368 |
517 |
(eflags & update_mask);
|
369 |
518 |
}
|
370 |
519 |
|
371 |
|
/* XXX: move that to a generic header */
|
372 |
|
#if !defined(CONFIG_USER_ONLY)
|
373 |
|
|
374 |
|
#define ldul_user ldl_user
|
375 |
|
#define ldul_kernel ldl_kernel
|
376 |
|
|
377 |
|
#define ACCESS_TYPE 0
|
378 |
|
#define MEMSUFFIX _kernel
|
379 |
|
#define DATA_SIZE 1
|
380 |
|
#include "softmmu_header.h"
|
381 |
|
|
382 |
|
#define DATA_SIZE 2
|
383 |
|
#include "softmmu_header.h"
|
384 |
|
|
385 |
|
#define DATA_SIZE 4
|
386 |
|
#include "softmmu_header.h"
|
387 |
|
|
388 |
|
#define DATA_SIZE 8
|
389 |
|
#include "softmmu_header.h"
|
390 |
|
#undef ACCESS_TYPE
|
391 |
|
#undef MEMSUFFIX
|
392 |
|
|
393 |
|
#define ACCESS_TYPE 1
|
394 |
|
#define MEMSUFFIX _user
|
395 |
|
#define DATA_SIZE 1
|
396 |
|
#include "softmmu_header.h"
|
397 |
|
|
398 |
|
#define DATA_SIZE 2
|
399 |
|
#include "softmmu_header.h"
|
400 |
|
|
401 |
|
#define DATA_SIZE 4
|
402 |
|
#include "softmmu_header.h"
|
403 |
|
|
404 |
|
#define DATA_SIZE 8
|
405 |
|
#include "softmmu_header.h"
|
406 |
|
#undef ACCESS_TYPE
|
407 |
|
#undef MEMSUFFIX
|
408 |
|
|
409 |
|
/* these access are slower, they must be as rare as possible */
|
410 |
|
#define ACCESS_TYPE 2
|
411 |
|
#define MEMSUFFIX _data
|
412 |
|
#define DATA_SIZE 1
|
413 |
|
#include "softmmu_header.h"
|
414 |
|
|
415 |
|
#define DATA_SIZE 2
|
416 |
|
#include "softmmu_header.h"
|
417 |
|
|
418 |
|
#define DATA_SIZE 4
|
419 |
|
#include "softmmu_header.h"
|
420 |
|
|
421 |
|
#define DATA_SIZE 8
|
422 |
|
#include "softmmu_header.h"
|
423 |
|
#undef ACCESS_TYPE
|
424 |
|
#undef MEMSUFFIX
|
425 |
|
|
426 |
|
#define ldub(p) ldub_data(p)
|
427 |
|
#define ldsb(p) ldsb_data(p)
|
428 |
|
#define lduw(p) lduw_data(p)
|
429 |
|
#define ldsw(p) ldsw_data(p)
|
430 |
|
#define ldl(p) ldl_data(p)
|
431 |
|
#define ldq(p) ldq_data(p)
|
432 |
|
|
433 |
|
#define stb(p, v) stb_data(p, v)
|
434 |
|
#define stw(p, v) stw_data(p, v)
|
435 |
|
#define stl(p, v) stl_data(p, v)
|
436 |
|
#define stq(p, v) stq_data(p, v)
|
437 |
|
|
438 |
|
static inline double ldfq(void *ptr)
|
439 |
|
{
|
440 |
|
union {
|
441 |
|
double d;
|
442 |
|
uint64_t i;
|
443 |
|
} u;
|
444 |
|
u.i = ldq(ptr);
|
445 |
|
return u.d;
|
446 |
|
}
|
447 |
|
|
448 |
|
static inline void stfq(void *ptr, double v)
|
449 |
|
{
|
450 |
|
union {
|
451 |
|
double d;
|
452 |
|
uint64_t i;
|
453 |
|
} u;
|
454 |
|
u.d = v;
|
455 |
|
stq(ptr, u.i);
|
456 |
|
}
|
457 |
|
|
458 |
|
static inline float ldfl(void *ptr)
|
459 |
|
{
|
460 |
|
union {
|
461 |
|
float f;
|
462 |
|
uint32_t i;
|
463 |
|
} u;
|
464 |
|
u.i = ldl(ptr);
|
465 |
|
return u.f;
|
466 |
|
}
|
467 |
|
|
468 |
|
static inline void stfl(void *ptr, float v)
|
469 |
|
{
|
470 |
|
union {
|
471 |
|
float f;
|
472 |
|
uint32_t i;
|
473 |
|
} u;
|
474 |
|
u.f = v;
|
475 |
|
stl(ptr, u.i);
|
476 |
|
}
|
477 |
|
|
478 |
|
#endif /* !defined(CONFIG_USER_ONLY) */
|