From 9a97898ea4be010c36dcc78536bdf0ed1d3f0121 Mon Sep 17 00:00:00 2001 From: ptitSeb Date: Mon, 17 Apr 2023 17:57:02 +0000 Subject: [RV64_DYNAREC] Added F3 0F BD and 66 29 opcodes --- src/dynarec/rv64/dynarec_rv64_66.c | 9 ++++++ src/dynarec/rv64/dynarec_rv64_f30f.c | 58 ++++++++++++++++++++++++++++++++++++ 2 files changed, 67 insertions(+) (limited to 'src') diff --git a/src/dynarec/rv64/dynarec_rv64_66.c b/src/dynarec/rv64/dynarec_rv64_66.c index 0bcebef5..55c79e9b 100644 --- a/src/dynarec/rv64/dynarec_rv64_66.c +++ b/src/dynarec/rv64/dynarec_rv64_66.c @@ -154,6 +154,15 @@ uintptr_t dynarec64_66(dynarec_rv64_t* dyn, uintptr_t addr, uintptr_t ip, int ni AND(xRAX, xRAX, x3); OR(xRAX, xRAX, x1); break; + case 0x29: + INST_NAME("SUB Ex, Gw"); + SETFLAGS(X_ALL, SF_SET_PENDING); + nextop = F8; + GETGW(x1); + GETEW(x2, 0); + emit_sub16(dyn, ninst, x2, x1, x3, x4, x5); + EWBACK; + break; case 0x2B: INST_NAME("SUB Gw, Ew"); SETFLAGS(X_ALL, SF_SET_PENDING); diff --git a/src/dynarec/rv64/dynarec_rv64_f30f.c b/src/dynarec/rv64/dynarec_rv64_f30f.c index d1b51258..d9700507 100644 --- a/src/dynarec/rv64/dynarec_rv64_f30f.c +++ b/src/dynarec/rv64/dynarec_rv64_f30f.c @@ -16,6 +16,7 @@ #include "emu/x64run_private.h" #include "x64trace.h" #include "dynarec_native.h" +#include "bitutils.h" #include "rv64_printer.h" #include "dynarec_rv64_private.h" @@ -223,6 +224,63 @@ uintptr_t dynarec64_F30F(dynarec_rv64_t* dyn, uintptr_t addr, uintptr_t ip, int SSE_LOOP_MV_Q2(x3); if(!MODREG) SMWRITE2(); break; + + case 0xBD: + INST_NAME("LZCNT Gd, Ed"); + SETFLAGS(X_ZF|X_CF, SF_SUBSET); + SET_DFNONE(); + nextop = F8; + GETED(0); + GETGD; + if(!rex.w && MODREG) { + AND(x4, ed, xMASK); + ed = x4; + } + BNE_MARK(ed, xZR); + MOV32w(gd, 0); + B_MARK2_nocond; + MARK; + ANDI(xFlags, xFlags, ~(1<