From c266b178983cd7c5e3b590bb3c4536ed585b3aca Mon Sep 17 00:00:00 2001 From: illusion98 <37698908+illusion98@users.noreply.github.com> Date: Sat, 26 Oct 2019 05:18:05 -0500 Subject: [PATCH] Add cvar for Unreal Engine 3 workaround --- src/xenia/cpu/ppc/ppc_emit_memory.cc | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/src/xenia/cpu/ppc/ppc_emit_memory.cc b/src/xenia/cpu/ppc/ppc_emit_memory.cc index ee347682c..fc8e2a3ea 100644 --- a/src/xenia/cpu/ppc/ppc_emit_memory.cc +++ b/src/xenia/cpu/ppc/ppc_emit_memory.cc @@ -8,12 +8,16 @@ */ #include "xenia/cpu/ppc/ppc_emit-private.h" - +#include "xenia/base/cvar.h" #include #include "xenia/base/assert.h" #include "xenia/cpu/ppc/ppc_context.h" #include "xenia/cpu/ppc/ppc_hir_builder.h" +DEFINE_bool(UE_Workaround, true, + "Workaround for Unreal Engine 3 titles to run, try disabling if other games have problems", + "CPU"); + namespace xe { namespace cpu { namespace ppc { @@ -1080,9 +1084,15 @@ int InstrEmit_stfsx(PPCHIRBuilder& f, const InstrData& i) { // https://randomascii.wordpress.com/2018/01/07/finding-a-cpu-design-bug-in-the-xbox-360/ int InstrEmit_dcbf(PPCHIRBuilder& f, const InstrData& i) { - Value* ea = CalculateEA_0(f, i.X.RA, i.X.RB); - f.CacheControl(ea, 128, - CacheControlType::CACHE_CONTROL_TYPE_DATA_STORE_AND_FLUSH); + //UE Hack + if ((i.X.RB == 11) && (cvars::UE_Workaround) && (f.CompareEQ(f.LoadGPR(i.X.RB), f.LoadConstantUint16(0xFEED)))) { + Value* val = f.Sub(f.LoadGPR(i.X.RB), f.LoadConstantUint64(0x0004)); + f.StoreGPR(i.X.RB, val); + } else { + Value* ea = CalculateEA_0(f, i.X.RA, i.X.RB); + f.CacheControl(ea, 128, + CacheControlType::CACHE_CONTROL_TYPE_DATA_STORE_AND_FLUSH); + } return 0; }