diff options
Diffstat (limited to 'src/dynarec/la64/dynarec_la64_avx.c')
| -rw-r--r-- | src/dynarec/la64/dynarec_la64_avx.c | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/src/dynarec/la64/dynarec_la64_avx.c b/src/dynarec/la64/dynarec_la64_avx.c new file mode 100644 index 00000000..1a8a14a7 --- /dev/null +++ b/src/dynarec/la64/dynarec_la64_avx.c @@ -0,0 +1,81 @@ +#include <stdio.h> +#include <stdlib.h> +#include <stddef.h> +#include <errno.h> + +#include "debug.h" +#include "box64context.h" +#include "box64cpu.h" +#include "emu/x64emu_private.h" +#include "x64emu.h" +#include "box64stack.h" +#include "callback.h" +#include "emu/x64run_private.h" +#include "x64trace.h" +#include "dynarec_native.h" + +#include "la64_printer.h" +#include "dynarec_la64_private.h" +#include "dynarec_la64_functions.h" +#include "dynarec_la64_helper.h" + +static const char* avx_prefix_string(uint16_t p) +{ + switch (p) { + case VEX_P_NONE: return "0"; + case VEX_P_66: return "66"; + case VEX_P_F2: return "F2"; + case VEX_P_F3: return "F3"; + default: return "??"; + } +} +static const char* avx_map_string(uint16_t m) +{ + switch (m) { + case VEX_M_NONE: return "0"; + case VEX_M_0F: return "0F"; + case VEX_M_0F38: return "0F38"; + case VEX_M_0F3A: return "0F3A"; + default: return "??"; + } +} + +uintptr_t dynarec64_AVX(dynarec_la64_t* dyn, uintptr_t addr, uintptr_t ip, int ninst, vex_t vex, int* ok, int* need_epilog) +{ + (void)ip; + (void)need_epilog; + + uint8_t opcode = PK(0); + rex_t rex = vex.rex; + + + if ((vex.m == VEX_M_0F) && (vex.p == VEX_P_NONE)) + addr = dynarec64_AVX_0F(dyn, addr, ip, ninst, vex, ok, need_epilog); + // else if( (vex.m==VEX_M_0F38) && (vex.p==VEX_P_NONE)) + // addr = dynarec64_AVX_0F38(dyn, addr, ip, ninst, vex, ok, need_epilog); + else if ((vex.m == VEX_M_0F) && (vex.p == VEX_P_66)) + addr = dynarec64_AVX_66_0F(dyn, addr, ip, ninst, vex, ok, need_epilog); + else if ((vex.m == VEX_M_0F) && (vex.p == VEX_P_F2)) + addr = dynarec64_AVX_F2_0F(dyn, addr, ip, ninst, vex, ok, need_epilog); + else if ((vex.m == VEX_M_0F) && (vex.p == VEX_P_F3)) + addr = dynarec64_AVX_F3_0F(dyn, addr, ip, ninst, vex, ok, need_epilog); + else if ((vex.m == VEX_M_0F38) && (vex.p == VEX_P_66)) + addr = dynarec64_AVX_66_0F38(dyn, addr, ip, ninst, vex, ok, need_epilog); + else if ((vex.m == VEX_M_0F3A) && (vex.p == VEX_P_66)) + addr = dynarec64_AVX_66_0F3A(dyn, addr, ip, ninst, vex, ok, need_epilog); + // else if( (vex.m==VEX_M_0F38) && (vex.p==VEX_P_F2)) + // addr = dynarec64_AVX_F2_0F38(dyn, addr, ip, ninst, vex, ok, need_epilog); + // else if( (vex.m==VEX_M_0F3A) && (vex.p==VEX_P_F2)) + // addr = dynarec64_AVX_F2_0F3A(dyn, addr, ip, ninst, vex, ok, need_epilog); + // else if( (vex.m==VEX_M_0F38) && (vex.p==VEX_P_F3)) + // addr = dynarec64_AVX_F3_0F38(dyn, addr, ip, ninst, vex, ok, need_epilog); + else { + DEFAULT; + } + + if((*ok==-1) && (BOX64ENV(dynarec_log)>=LOG_INFO || dyn->need_dump || BOX64ENV(dynarec_missing))) + if(!dyn->size || BOX64ENV(dynarec_log)>LOG_INFO || dyn->need_dump) { + dynarec_log(LOG_NONE, " Dynarec unimplemented VEX opcode size %d prefix %s map %s opcode %02X\n", 128<<vex.l, avx_prefix_string(vex.p), avx_map_string(vex.m), opcode); + } + return addr; +} \ No newline at end of file |