From 6046a15267c5aa5bab4333182d4bb7798f4fa4a9 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Wed, 30 Dec 2020 20:29:57 -0500 Subject: [PATCH] Arm64Emitter: Make ShiftAmount enum an enum class Reduces namespace pollution and makes the enum strongly typed. --- Source/Core/Common/Arm64Emitter.cpp | 7 ++++--- Source/Core/Common/Arm64Emitter.h | 16 ++++++++-------- .../Core/Core/PowerPC/JitArm64/JitArm64Cache.cpp | 4 ++-- 3 files changed, 14 insertions(+), 13 deletions(-) diff --git a/Source/Core/Common/Arm64Emitter.cpp b/Source/Core/Common/Arm64Emitter.cpp index ce0820bff8..ff1a6b137f 100644 --- a/Source/Core/Common/Arm64Emitter.cpp +++ b/Source/Core/Common/Arm64Emitter.cpp @@ -767,7 +767,8 @@ void ARM64XEmitter::EncodeMOVWideInst(u32 op, ARM64Reg Rd, u32 imm, ShiftAmount ASSERT_MSG(DYNA_REC, !(imm & ~0xFFFF), "%s: immediate out of range: %d", __func__, imm); Rd = DecodeReg(Rd); - Write32((b64Bit << 31) | (op << 29) | (0x25 << 23) | (pos << 21) | (imm << 5) | Rd); + Write32((b64Bit << 31) | (op << 29) | (0x25 << 23) | (static_cast(pos) << 21) | (imm << 5) | + Rd); } void ARM64XEmitter::EncodeBitfieldMOVInst(u32 op, ARM64Reg Rd, ARM64Reg Rn, u32 immr, u32 imms) @@ -2004,7 +2005,7 @@ void ARM64XEmitter::MOVI2R(ARM64Reg Rd, u64 imm, bool optimize) { // Zero immediate, just clear the register. EOR is pointless when we have MOVZ, which looks // clearer in disasm too. - MOVZ(Rd, 0, SHIFT_0); + MOVZ(Rd, 0, ShiftAmount::Shift0); return; } @@ -2022,7 +2023,7 @@ void ARM64XEmitter::MOVI2R(ARM64Reg Rd, u64 imm, bool optimize) // Small negative integer. Use MOVN if (!Is64Bit(Rd) && (imm | 0xFFFF0000) == imm) { - MOVN(Rd, ~imm, SHIFT_0); + MOVN(Rd, ~imm, ShiftAmount::Shift0); return; } diff --git a/Source/Core/Common/Arm64Emitter.h b/Source/Core/Common/Arm64Emitter.h index 21f371ada3..3e752dbf07 100644 --- a/Source/Core/Common/Arm64Emitter.h +++ b/Source/Core/Common/Arm64Emitter.h @@ -302,12 +302,12 @@ enum IndexType INDEX_SIGNED, // used in LDP/STP }; -enum ShiftAmount +enum class ShiftAmount { - SHIFT_0 = 0, - SHIFT_16 = 1, - SHIFT_32 = 2, - SHIFT_48 = 3, + Shift0, + Shift16, + Shift32, + Shift48, }; enum class RoundingMode @@ -737,9 +737,9 @@ public: void CMP(ARM64Reg Rn, u32 imm, bool shift = false); // Data Processing (Immediate) - void MOVZ(ARM64Reg Rd, u32 imm, ShiftAmount pos = SHIFT_0); - void MOVN(ARM64Reg Rd, u32 imm, ShiftAmount pos = SHIFT_0); - void MOVK(ARM64Reg Rd, u32 imm, ShiftAmount pos = SHIFT_0); + void MOVZ(ARM64Reg Rd, u32 imm, ShiftAmount pos = ShiftAmount::Shift0); + void MOVN(ARM64Reg Rd, u32 imm, ShiftAmount pos = ShiftAmount::Shift0); + void MOVK(ARM64Reg Rd, u32 imm, ShiftAmount pos = ShiftAmount::Shift0); // Bitfield move void BFM(ARM64Reg Rd, ARM64Reg Rn, u32 immr, u32 imms); diff --git a/Source/Core/Core/PowerPC/JitArm64/JitArm64Cache.cpp b/Source/Core/Core/PowerPC/JitArm64/JitArm64Cache.cpp index a02cabe6a0..b9fd37ec24 100644 --- a/Source/Core/Core/PowerPC/JitArm64/JitArm64Cache.cpp +++ b/Source/Core/Core/PowerPC/JitArm64/JitArm64Cache.cpp @@ -19,8 +19,8 @@ void JitArm64BlockCache::WriteLinkBlock(Arm64Gen::ARM64XEmitter& emit, if (!dest) { // Use a fixed amount of instructions, so we can assume to use 3 instructions on patching. - emit.MOVZ(DISPATCHER_PC, source.exitAddress & 0xFFFF, SHIFT_0); - emit.MOVK(DISPATCHER_PC, source.exitAddress >> 16, SHIFT_16); + emit.MOVZ(DISPATCHER_PC, source.exitAddress & 0xFFFF, ShiftAmount::Shift0); + emit.MOVK(DISPATCHER_PC, source.exitAddress >> 16, ShiftAmount::Shift16); if (source.call) emit.BL(m_jit.GetAsmRoutines()->dispatcher);