From 875b0b91f18b853d46453ac19e647538812a5850 Mon Sep 17 00:00:00 2001 From: Connor McLaughlin Date: Mon, 26 Oct 2020 22:02:33 +1000 Subject: [PATCH] CPU/Recompiler/AArch64: Use scratch for add CPU struct field --- .../cpu_recompiler_code_generator_aarch64.cpp | 33 +++++++++---------- 1 file changed, 16 insertions(+), 17 deletions(-) diff --git a/src/core/cpu_recompiler_code_generator_aarch64.cpp b/src/core/cpu_recompiler_code_generator_aarch64.cpp index 250ff2368..59a2fb74c 100644 --- a/src/core/cpu_recompiler_code_generator_aarch64.cpp +++ b/src/core/cpu_recompiler_code_generator_aarch64.cpp @@ -1226,50 +1226,49 @@ void CodeGenerator::EmitAddCPUStructField(u32 offset, const Value& value) const a64::MemOperand o_offset(GetCPUPtrReg(), s_offset); // Don't need to mask here because we're storing back to memory. - Value temp = m_register_cache.AllocateScratch(value.size); switch (value.size) { case RegSize_8: { - m_emit->Ldrb(GetHostReg8(temp), o_offset); + m_emit->Ldrb(GetHostReg8(RSCRATCH), o_offset); if (value.IsConstant()) - m_emit->Add(GetHostReg8(temp), GetHostReg8(temp), value.GetS64ConstantValue()); + m_emit->Add(GetHostReg8(RSCRATCH), GetHostReg8(RSCRATCH), value.GetS64ConstantValue()); else - m_emit->Add(GetHostReg8(temp), GetHostReg8(temp), GetHostReg8(value)); - m_emit->Strb(GetHostReg8(temp), o_offset); + m_emit->Add(GetHostReg8(RSCRATCH), GetHostReg8(RSCRATCH), GetHostReg8(value)); + m_emit->Strb(GetHostReg8(RSCRATCH), o_offset); } break; case RegSize_16: { - m_emit->Ldrh(GetHostReg16(temp), o_offset); + m_emit->Ldrh(GetHostReg16(RSCRATCH), o_offset); if (value.IsConstant()) - m_emit->Add(GetHostReg16(temp), GetHostReg16(temp), value.GetS64ConstantValue()); + m_emit->Add(GetHostReg16(RSCRATCH), GetHostReg16(RSCRATCH), value.GetS64ConstantValue()); else - m_emit->Add(GetHostReg16(temp), GetHostReg16(temp), GetHostReg16(value)); - m_emit->Strh(GetHostReg16(temp), o_offset); + m_emit->Add(GetHostReg16(RSCRATCH), GetHostReg16(RSCRATCH), GetHostReg16(value)); + m_emit->Strh(GetHostReg16(RSCRATCH), o_offset); } break; case RegSize_32: { - m_emit->Ldr(GetHostReg32(temp), o_offset); + m_emit->Ldr(GetHostReg32(RSCRATCH), o_offset); if (value.IsConstant()) - m_emit->Add(GetHostReg32(temp), GetHostReg32(temp), value.GetS64ConstantValue()); + m_emit->Add(GetHostReg32(RSCRATCH), GetHostReg32(RSCRATCH), value.GetS64ConstantValue()); else - m_emit->Add(GetHostReg32(temp), GetHostReg32(temp), GetHostReg32(value)); - m_emit->Str(GetHostReg32(temp), o_offset); + m_emit->Add(GetHostReg32(RSCRATCH), GetHostReg32(RSCRATCH), GetHostReg32(value)); + m_emit->Str(GetHostReg32(RSCRATCH), o_offset); } break; case RegSize_64: { - m_emit->Ldr(GetHostReg64(temp), o_offset); + m_emit->Ldr(GetHostReg64(RSCRATCH), o_offset); if (value.IsConstant()) - m_emit->Add(GetHostReg64(temp), GetHostReg64(temp), s64(value.constant_value)); + m_emit->Add(GetHostReg64(RSCRATCH), GetHostReg64(RSCRATCH), s64(value.constant_value)); else - m_emit->Add(GetHostReg64(temp), GetHostReg64(temp), GetHostReg64(value)); - m_emit->Str(GetHostReg64(temp), o_offset); + m_emit->Add(GetHostReg64(RSCRATCH), GetHostReg64(RSCRATCH), GetHostReg64(value)); + m_emit->Str(GetHostReg64(RSCRATCH), o_offset); } break;