diff --git a/src/dynarmic/backend/arm64/emit_arm64_data_processing.cpp b/src/dynarmic/backend/arm64/emit_arm64_data_processing.cpp index a1e618fb..04395148 100644 --- a/src/dynarmic/backend/arm64/emit_arm64_data_processing.cpp +++ b/src/dynarmic/backend/arm64/emit_arm64_data_processing.cpp @@ -898,6 +898,7 @@ static void EmitAddSub(oaknut::CodeGenerator& code, EmitContext& ctx, IR::Inst* auto Rb = ctx.reg_alloc.ReadReg(args[1]); auto Woverflow = ctx.reg_alloc.WriteW(overflow_inst); + ctx.reg_alloc.SpillFlags(); RegAlloc::Realize(Rresult, Ra, Rb, Woverflow); code.ADDS(Rresult, *Ra, Rb);