mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-26 07:45:33 +01:00
Arm64Emitter: Make RoundingMode enum an enum class
Prevents namespace pollution and makes the enum members strongly typed.
This commit is contained in:
parent
d87ec71615
commit
fab2053439
@ -2327,28 +2327,28 @@ void ARM64FloatEmitter::EmitConvertScalarToInt(ARM64Reg Rd, ARM64Reg Rn, Roundin
|
|||||||
if (IsGPR(Rd))
|
if (IsGPR(Rd))
|
||||||
{
|
{
|
||||||
// Use the encoding that transfers the result to a GPR.
|
// Use the encoding that transfers the result to a GPR.
|
||||||
bool sf = Is64Bit(Rd);
|
const bool sf = Is64Bit(Rd);
|
||||||
int type = IsDouble(Rn) ? 1 : 0;
|
const int type = IsDouble(Rn) ? 1 : 0;
|
||||||
Rd = DecodeReg(Rd);
|
Rd = DecodeReg(Rd);
|
||||||
Rn = DecodeReg(Rn);
|
Rn = DecodeReg(Rn);
|
||||||
int opcode = (sign ? 1 : 0);
|
int opcode = (sign ? 1 : 0);
|
||||||
int rmode = 0;
|
int rmode = 0;
|
||||||
switch (round)
|
switch (round)
|
||||||
{
|
{
|
||||||
case ROUND_A:
|
case RoundingMode::A:
|
||||||
rmode = 0;
|
rmode = 0;
|
||||||
opcode |= 4;
|
opcode |= 4;
|
||||||
break;
|
break;
|
||||||
case ROUND_P:
|
case RoundingMode::P:
|
||||||
rmode = 1;
|
rmode = 1;
|
||||||
break;
|
break;
|
||||||
case ROUND_M:
|
case RoundingMode::M:
|
||||||
rmode = 2;
|
rmode = 2;
|
||||||
break;
|
break;
|
||||||
case ROUND_Z:
|
case RoundingMode::Z:
|
||||||
rmode = 3;
|
rmode = 3;
|
||||||
break;
|
break;
|
||||||
case ROUND_N:
|
case RoundingMode::N:
|
||||||
rmode = 0;
|
rmode = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -2363,20 +2363,20 @@ void ARM64FloatEmitter::EmitConvertScalarToInt(ARM64Reg Rd, ARM64Reg Rn, Roundin
|
|||||||
int opcode = 0;
|
int opcode = 0;
|
||||||
switch (round)
|
switch (round)
|
||||||
{
|
{
|
||||||
case ROUND_A:
|
case RoundingMode::A:
|
||||||
opcode = 0x1C;
|
opcode = 0x1C;
|
||||||
break;
|
break;
|
||||||
case ROUND_N:
|
case RoundingMode::N:
|
||||||
opcode = 0x1A;
|
opcode = 0x1A;
|
||||||
break;
|
break;
|
||||||
case ROUND_M:
|
case RoundingMode::M:
|
||||||
opcode = 0x1B;
|
opcode = 0x1B;
|
||||||
break;
|
break;
|
||||||
case ROUND_P:
|
case RoundingMode::P:
|
||||||
opcode = 0x1A;
|
opcode = 0x1A;
|
||||||
sz |= 2;
|
sz |= 2;
|
||||||
break;
|
break;
|
||||||
case ROUND_Z:
|
case RoundingMode::Z:
|
||||||
opcode = 0x1B;
|
opcode = 0x1B;
|
||||||
sz |= 2;
|
sz |= 2;
|
||||||
break;
|
break;
|
||||||
|
@ -310,13 +310,13 @@ enum ShiftAmount
|
|||||||
SHIFT_48 = 3,
|
SHIFT_48 = 3,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum RoundingMode
|
enum class RoundingMode
|
||||||
{
|
{
|
||||||
ROUND_A, // round to nearest, ties to away
|
A, // round to nearest, ties to away
|
||||||
ROUND_M, // round towards -inf
|
M, // round towards -inf
|
||||||
ROUND_N, // round to nearest, ties to even
|
N, // round to nearest, ties to even
|
||||||
ROUND_P, // round towards +inf
|
P, // round towards +inf
|
||||||
ROUND_Z, // round towards zero
|
Z, // round towards zero
|
||||||
};
|
};
|
||||||
|
|
||||||
struct FixupBranch
|
struct FixupBranch
|
||||||
|
@ -335,13 +335,13 @@ void JitArm64::fctiwzx(UGeckoInstruction inst)
|
|||||||
|
|
||||||
if (single)
|
if (single)
|
||||||
{
|
{
|
||||||
m_float_emit.FCVTS(EncodeRegToSingle(VD), EncodeRegToSingle(VB), ROUND_Z);
|
m_float_emit.FCVTS(EncodeRegToSingle(VD), EncodeRegToSingle(VB), RoundingMode::Z);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ARM64Reg V1 = gpr.GetReg();
|
ARM64Reg V1 = gpr.GetReg();
|
||||||
|
|
||||||
m_float_emit.FCVTS(V1, EncodeRegToDouble(VB), ROUND_Z);
|
m_float_emit.FCVTS(V1, EncodeRegToDouble(VB), RoundingMode::Z);
|
||||||
m_float_emit.FMOV(EncodeRegToSingle(VD), V1);
|
m_float_emit.FMOV(EncodeRegToSingle(VD), V1);
|
||||||
|
|
||||||
gpr.Unlock(V1);
|
gpr.Unlock(V1);
|
||||||
|
@ -261,7 +261,7 @@ void JitArm64::mfspr(UGeckoInstruction inst)
|
|||||||
m_float_emit.LDR(32, INDEX_UNSIGNED, SD, Xg,
|
m_float_emit.LDR(32, INDEX_UNSIGNED, SD, Xg,
|
||||||
offsetof(CoreTiming::Globals, last_OC_factor_inverted));
|
offsetof(CoreTiming::Globals, last_OC_factor_inverted));
|
||||||
m_float_emit.FMUL(SC, SC, SD);
|
m_float_emit.FMUL(SC, SC, SD);
|
||||||
m_float_emit.FCVTS(Xresult, SC, ROUND_Z);
|
m_float_emit.FCVTS(Xresult, SC, RoundingMode::Z);
|
||||||
|
|
||||||
LDP(INDEX_SIGNED, XA, XB, Xg, offsetof(CoreTiming::Globals, global_timer));
|
LDP(INDEX_SIGNED, XA, XB, Xg, offsetof(CoreTiming::Globals, global_timer));
|
||||||
SXTW(XB, WB);
|
SXTW(XB, WB);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user