48 lines
966 B
C
48 lines
966 B
C
#define C0 (1<<8)
|
|
#define C1 (1<<9)
|
|
#define C2 (1<<10)
|
|
#define C3 (1<<14)
|
|
|
|
extern uint32_t x87_pc_off,x87_op_off;
|
|
extern uint16_t x87_pc_seg,x87_op_seg;
|
|
|
|
static __inline void x87_set_mmx()
|
|
{
|
|
uint64_t *p;
|
|
cpu_state.TOP = 0;
|
|
p = (uint64_t *)cpu_state.tag;
|
|
*p = 0x0101010101010101ull;
|
|
cpu_state.ismmx = 1;
|
|
}
|
|
|
|
static __inline void x87_emms()
|
|
{
|
|
uint64_t *p;
|
|
p = (uint64_t *)cpu_state.tag;
|
|
*p = 0;
|
|
cpu_state.ismmx = 0;
|
|
}
|
|
|
|
|
|
uint16_t x87_gettag();
|
|
void x87_settag(uint16_t new_tag);
|
|
|
|
#define TAG_EMPTY 0
|
|
#define TAG_VALID (1 << 0)
|
|
/*Hack for FPU copy. If set then MM[].q contains the 64-bit integer loaded by FILD*/
|
|
#ifdef USE_NEW_DYNAREC
|
|
#define TAG_UINT64 (1 << 7)
|
|
#else
|
|
#define TAG_UINT64 (1 << 2)
|
|
#endif
|
|
|
|
/*Old dynarec stuff.*/
|
|
#define TAG_NOT_UINT64 0xfb
|
|
|
|
#define X87_ROUNDING_NEAREST 0
|
|
#define X87_ROUNDING_DOWN 1
|
|
#define X87_ROUNDING_UP 2
|
|
#define X87_ROUNDING_CHOP 3
|
|
|
|
void codegen_set_rounding_mode(int mode);
|