diff --git a/rpcs3/Emu/Cell/PPUThread.cpp b/rpcs3/Emu/Cell/PPUThread.cpp index 592386b272..6abed133b9 100644 --- a/rpcs3/Emu/Cell/PPUThread.cpp +++ b/rpcs3/Emu/Cell/PPUThread.cpp @@ -710,8 +710,8 @@ struct ppu_far_jumps_t Label jmp_address = c.newLabel(); Label imm_address = c.newLabel(); - c.ldr(args[1].r32(), arm::ptr(imm_address)); - c.str(args[1].r32(), arm::Mem(args[0], ::offset32(&ppu_thread::cia))); + c.ldr(args[1].w(), arm::ptr(imm_address)); + c.str(args[1].w(), arm::Mem(args[0], ::offset32(&ppu_thread::cia))); c.ldr(args[1], arm::ptr(jmp_address)); c.br(args[1]); diff --git a/rpcs3/Emu/RSX/Common/BufferUtils.cpp b/rpcs3/Emu/RSX/Common/BufferUtils.cpp index 9de37fdbd8..394a51637e 100644 --- a/rpcs3/Emu/RSX/Common/BufferUtils.cpp +++ b/rpcs3/Emu/RSX/Common/BufferUtils.cpp @@ -360,10 +360,14 @@ namespace u32 count = ::size32(src); u64 r; +#if defined(ARCH_X64) if constexpr (sizeof(T) == 2) r = upload_xi16(src.data(), dst.data(), count); else r = upload_xi32(src.data(), dst.data(), count); +#else + r = upload_untouched_naive(src.data(), dst.data(), count); +#endif min_index = r; max_index = r >> 32;