From 65c31b5640644a9f730dd7a68dac29f312d04c82 Mon Sep 17 00:00:00 2001 From: Simonas Kazlauskas Date: Tue, 14 Dec 2021 17:23:54 +0200 Subject: [PATCH] Backport upstream #2723 Co-authored-by: ptitSeb --- lib/compiler-singlepass/src/codegen_x64.rs | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/lib/compiler-singlepass/src/codegen_x64.rs b/lib/compiler-singlepass/src/codegen_x64.rs index ab66664377..6b392e4972 100644 --- a/lib/compiler-singlepass/src/codegen_x64.rs +++ b/lib/compiler-singlepass/src/codegen_x64.rs @@ -1313,16 +1313,12 @@ impl<'a> FuncGen<'a> { } match *param { Location::Imm64(_) => { - // Dummy value slot to be filled with `mov`. - self.assembler.emit_push(Size::S64, Location::GPR(GPR::RAX)); - - // Use R9 as the temporary register here, since: - // - It is a temporary register that is not used for any persistent value. - // - This register as an argument location is only written to after `sort_call_movs`.' + // Push R9 value slot to be exchange with `mov`. + self.assembler.emit_push(Size::S64, Location::GPR(GPR::R9)); self.machine.reserve_unused_temp_gpr(GPR::R9); self.assembler .emit_mov(Size::S64, *param, Location::GPR(GPR::R9)); - self.assembler.emit_mov( + self.assembler.emit_xchg( Size::S64, Location::GPR(GPR::R9), Location::Memory(GPR::RSP, 0),