1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
#ifndef __DYNAREC_LA64_FUNCTIONS_H__
#define __DYNAREC_LA64_FUNCTIONS_H__
#include "../dynarec_native_functions.h"
#define SCRATCH0 24
typedef struct x64emu_s x64emu_t;
typedef struct dynarec_la64_s dynarec_la64_t;
// Get an FPU scratch reg
int fpu_get_scratch(dynarec_la64_t* dyn);
// Reset scratch regs counter
void fpu_reset_scratch(dynarec_la64_t* dyn);
// Get an x87 double reg
int fpu_get_reg_x87(dynarec_la64_t* dyn, int t, int n);
// Get an XMM quad reg
int fpu_get_reg_xmm(dynarec_la64_t* dyn, int t, int xmm);
// Get an YMM quad reg
int fpu_get_reg_ymm(dynarec_la64_t* dyn, int t, int ymm);
// Free a FPU/MMX/XMM reg
void fpu_free_reg(dynarec_la64_t* dyn, int reg);
// Reset fpu regs counter
void fpu_reset_reg(dynarec_la64_t* dyn);
// Get an MMX double reg
int fpu_get_reg_emm(dynarec_la64_t* dyn, int emm);
// Get type for STx
int lsxcache_get_st(dynarec_la64_t* dyn, int ninst, int a);
// Get if STx is FLOAT or DOUBLE
int lsxcache_get_st_f(dynarec_la64_t* dyn, int ninst, int a);
// Get if STx is FLOAT or I64
int lsxcache_get_st_f_i64(dynarec_la64_t* dyn, int ninst, int a);
// Get actual type for STx
int lsxcache_get_current_st(dynarec_la64_t* dyn, int ninst, int a);
// Get actual STx is FLOAT or DOUBLE
int lsxcache_get_current_st_f(dynarec_la64_t* dyn, int a);
// Get actual STx is FLOAT or I64
int lsxcache_get_current_st_f_i64(dynarec_la64_t* dyn, int a);
// Back-propagate a change float->double
void lsxcache_promote_double(dynarec_la64_t* dyn, int ninst, int a);
// Combine and propagate if needed (pass 1 only)
int lsxcache_combine_st(dynarec_la64_t* dyn, int ninst, int a, int b); // with stack current dyn->n_stack*
// Do not allow i64 type
int lsxcache_no_i64(dynarec_la64_t* dyn, int ninst, int st, int a);
// FPU Cache transformation (for loops) // Specific, need to be written by backend
int fpuCacheNeedsTransform(dynarec_la64_t* dyn, int ninst);
// Undo the changes of a lsxcache to get the status before the instruction
void lsxcacheUnwind(lsxcache_t* cache);
void fpu_save_and_unwind(dynarec_la64_t* dyn, int ninst, lsxcache_t* cache);
void fpu_unwind_restore(dynarec_la64_t* dyn, int ninst, lsxcache_t* cache);
const char* getCacheName(int t, int n);
void inst_name_pass3(dynarec_native_t* dyn, int ninst, const char* name, rex_t rex);
void print_opcode(dynarec_native_t* dyn, int ninst, uint32_t opcode);
// reset the cache
void fpu_reset(dynarec_native_t* dyn);
void fpu_reset_ninst(dynarec_native_t* dyn, int ninst);
// is st freed
int fpu_is_st_freed(dynarec_native_t* dyn, int ninst, int st);
void updateNativeFlags(dynarec_la64_t* dyn);
void get_free_scratch(dynarec_la64_t* dyn, int ninst, uint8_t* tmp1, uint8_t* tmp2, uint8_t* tmp3, uint8_t s1, uint8_t s2, uint8_t s3, uint8_t s4, uint8_t s5);
#endif //__DYNAREC_LA64_FUNCTIONS_H__
|