Apply new naming rule to all projects except Vp9 (#5407)
This commit is contained in:
parent
b186ec9fc5
commit
fbaf62c230
42 changed files with 334 additions and 335 deletions
|
@ -1296,11 +1296,11 @@ namespace ARMeilleure.CodeGen.X86
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const byte mask = 0b01_00_11_10;
|
const byte Mask = 0b01_00_11_10;
|
||||||
|
|
||||||
context.Assembler.Pshufd(src1, src1, mask);
|
context.Assembler.Pshufd(src1, src1, Mask);
|
||||||
context.Assembler.Movq(dest, src1);
|
context.Assembler.Movq(dest, src1);
|
||||||
context.Assembler.Pshufd(src1, src1, mask);
|
context.Assembler.Pshufd(src1, src1, Mask);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1853,9 +1853,9 @@ namespace ARMeilleure.CodeGen.X86
|
||||||
// that the OS will map all pages that we'll use. We do that by
|
// that the OS will map all pages that we'll use. We do that by
|
||||||
// doing a dummy read on those pages, forcing a page fault and
|
// doing a dummy read on those pages, forcing a page fault and
|
||||||
// the OS to map them. If they are already mapped, nothing happens.
|
// the OS to map them. If they are already mapped, nothing happens.
|
||||||
const int pageMask = PageSize - 1;
|
const int PageMask = PageSize - 1;
|
||||||
|
|
||||||
size = (size + pageMask) & ~pageMask;
|
size = (size + PageMask) & ~PageMask;
|
||||||
|
|
||||||
Operand rsp = Register(X86Register.Rsp);
|
Operand rsp = Register(X86Register.Rsp);
|
||||||
Operand temp = Register(CallingConvention.GetIntReturnRegister());
|
Operand temp = Register(CallingConvention.GetIntReturnRegister());
|
||||||
|
|
|
@ -304,9 +304,9 @@ namespace ARMeilleure.Decoders
|
||||||
}
|
}
|
||||||
else if (opCode is IOpCode32MemMult opMemMult)
|
else if (opCode is IOpCode32MemMult opMemMult)
|
||||||
{
|
{
|
||||||
const int pcMask = 1 << RegisterAlias.Aarch32Pc;
|
const int PCMask = 1 << RegisterAlias.Aarch32Pc;
|
||||||
|
|
||||||
rt = (opMemMult.RegisterMask & pcMask) != 0 ? RegisterAlias.Aarch32Pc : 0;
|
rt = (opMemMult.RegisterMask & PCMask) != 0 ? RegisterAlias.Aarch32Pc : 0;
|
||||||
rn = opMemMult.Rn;
|
rn = opMemMult.Rn;
|
||||||
wBack = opMemMult.PostOffset != 0;
|
wBack = opMemMult.PostOffset != 0;
|
||||||
isLoad = opMemMult.IsLoad;
|
isLoad = opMemMult.IsLoad;
|
||||||
|
|
|
@ -17,7 +17,7 @@ namespace ARMeilleure.Decoders.Optimizations
|
||||||
throw new InvalidOperationException("Function entry point is not contained in a block.");
|
throw new InvalidOperationException("Function entry point is not contained in a block.");
|
||||||
}
|
}
|
||||||
|
|
||||||
const ulong allowance = 4;
|
const ulong Allowance = 4;
|
||||||
|
|
||||||
Block entryBlock = blocks[entryBlockId];
|
Block entryBlock = blocks[entryBlockId];
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ namespace ARMeilleure.Decoders.Optimizations
|
||||||
{
|
{
|
||||||
Block block = blocks[i];
|
Block block = blocks[i];
|
||||||
|
|
||||||
if (endBlock.EndAddress < block.Address - allowance)
|
if (endBlock.EndAddress < block.Address - Allowance)
|
||||||
{
|
{
|
||||||
break; // End of contiguous function.
|
break; // End of contiguous function.
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,7 @@ namespace ARMeilleure.Decoders.Optimizations
|
||||||
{
|
{
|
||||||
Block block = blocks[i];
|
Block block = blocks[i];
|
||||||
|
|
||||||
if (startBlock.Address > block.EndAddress + allowance)
|
if (startBlock.Address > block.EndAddress + Allowance)
|
||||||
{
|
{
|
||||||
break; // End of contiguous function.
|
break; // End of contiguous function.
|
||||||
}
|
}
|
||||||
|
|
|
@ -1299,17 +1299,17 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
Debug.Assert((op.Size & 1) == 0 && op.RegisterSize == RegisterSize.Simd128);
|
Debug.Assert((op.Size & 1) == 0 && op.RegisterSize == RegisterSize.Simd128);
|
||||||
|
|
||||||
const int sm0 = 0 << 6 | 0 << 4 | 0 << 2 | 0 << 0;
|
const int SM0 = 0 << 6 | 0 << 4 | 0 << 2 | 0 << 0;
|
||||||
const int sm1 = 1 << 6 | 1 << 4 | 1 << 2 | 1 << 0;
|
const int SM1 = 1 << 6 | 1 << 4 | 1 << 2 | 1 << 0;
|
||||||
const int sm2 = 2 << 6 | 2 << 4 | 2 << 2 | 2 << 0;
|
const int SM2 = 2 << 6 | 2 << 4 | 2 << 2 | 2 << 0;
|
||||||
const int sm3 = 3 << 6 | 3 << 4 | 3 << 2 | 3 << 0;
|
const int SM3 = 3 << 6 | 3 << 4 | 3 << 2 | 3 << 0;
|
||||||
|
|
||||||
Operand nCopy = context.Copy(GetVec(op.Rn));
|
Operand nCopy = context.Copy(GetVec(op.Rn));
|
||||||
|
|
||||||
Operand part0 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, nCopy, Const(sm0));
|
Operand part0 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, nCopy, Const(SM0));
|
||||||
Operand part1 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, nCopy, Const(sm1));
|
Operand part1 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, nCopy, Const(SM1));
|
||||||
Operand part2 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, nCopy, Const(sm2));
|
Operand part2 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, nCopy, Const(SM2));
|
||||||
Operand part3 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, nCopy, Const(sm3));
|
Operand part3 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, nCopy, Const(SM3));
|
||||||
|
|
||||||
Operand res = emit(emit(part0, part1), emit(part2, part3));
|
Operand res = emit(emit(part0, part1), emit(part2, part3));
|
||||||
|
|
||||||
|
@ -1340,13 +1340,13 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
if ((op.Size & 1) == 0)
|
if ((op.Size & 1) == 0)
|
||||||
{
|
{
|
||||||
const int sm0 = 2 << 6 | 2 << 4 | 2 << 2 | 0 << 0;
|
const int SM0 = 2 << 6 | 2 << 4 | 2 << 2 | 0 << 0;
|
||||||
const int sm1 = 2 << 6 | 2 << 4 | 2 << 2 | 1 << 0;
|
const int SM1 = 2 << 6 | 2 << 4 | 2 << 2 | 1 << 0;
|
||||||
|
|
||||||
Operand zeroN = context.VectorZeroUpper64(n);
|
Operand zeroN = context.VectorZeroUpper64(n);
|
||||||
|
|
||||||
op0 = context.AddIntrinsic(Intrinsic.X86Pshufd, zeroN, Const(sm0));
|
op0 = context.AddIntrinsic(Intrinsic.X86Pshufd, zeroN, Const(SM0));
|
||||||
op1 = context.AddIntrinsic(Intrinsic.X86Pshufd, zeroN, Const(sm1));
|
op1 = context.AddIntrinsic(Intrinsic.X86Pshufd, zeroN, Const(SM1));
|
||||||
}
|
}
|
||||||
else /* if ((op.Size & 1) == 1) */
|
else /* if ((op.Size & 1) == 1) */
|
||||||
{
|
{
|
||||||
|
@ -1412,11 +1412,11 @@ namespace ARMeilleure.Instructions
|
||||||
}
|
}
|
||||||
else /* if (op.RegisterSize == RegisterSize.Simd128) */
|
else /* if (op.RegisterSize == RegisterSize.Simd128) */
|
||||||
{
|
{
|
||||||
const int sm0 = 2 << 6 | 0 << 4 | 2 << 2 | 0 << 0;
|
const int SM0 = 2 << 6 | 0 << 4 | 2 << 2 | 0 << 0;
|
||||||
const int sm1 = 3 << 6 | 1 << 4 | 3 << 2 | 1 << 0;
|
const int SM1 = 3 << 6 | 1 << 4 | 3 << 2 | 1 << 0;
|
||||||
|
|
||||||
Operand part0 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, mCopy, Const(sm0));
|
Operand part0 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, mCopy, Const(SM0));
|
||||||
Operand part1 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, mCopy, Const(sm1));
|
Operand part1 = context.AddIntrinsic(Intrinsic.X86Shufps, nCopy, mCopy, Const(SM1));
|
||||||
|
|
||||||
context.Copy(GetVec(op.Rd), emit(part0, part1));
|
context.Copy(GetVec(op.Rd), emit(part0, part1));
|
||||||
}
|
}
|
||||||
|
|
|
@ -408,7 +408,7 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
if (Optimizations.UseGfni)
|
if (Optimizations.UseGfni)
|
||||||
{
|
{
|
||||||
const long bitMatrix =
|
const long BitMatrix =
|
||||||
(0b10000000L << 56) |
|
(0b10000000L << 56) |
|
||||||
(0b01000000L << 48) |
|
(0b01000000L << 48) |
|
||||||
(0b00100000L << 40) |
|
(0b00100000L << 40) |
|
||||||
|
@ -418,7 +418,7 @@ namespace ARMeilleure.Instructions
|
||||||
(0b00000010L << 8) |
|
(0b00000010L << 8) |
|
||||||
(0b00000001L << 0);
|
(0b00000001L << 0);
|
||||||
|
|
||||||
Operand vBitMatrix = X86GetAllElements(context, bitMatrix);
|
Operand vBitMatrix = X86GetAllElements(context, BitMatrix);
|
||||||
|
|
||||||
Operand res = context.AddIntrinsic(Intrinsic.X86Gf2p8affineqb, GetVec(op.Rn), vBitMatrix, Const(0));
|
Operand res = context.AddIntrinsic(Intrinsic.X86Gf2p8affineqb, GetVec(op.Rn), vBitMatrix, Const(0));
|
||||||
|
|
||||||
|
@ -469,12 +469,12 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
Operand n = GetVec(op.Rn);
|
Operand n = GetVec(op.Rn);
|
||||||
|
|
||||||
const long maskE0 = 06L << 56 | 07L << 48 | 04L << 40 | 05L << 32 | 02L << 24 | 03L << 16 | 00L << 8 | 01L << 0;
|
const long MaskE0 = 06L << 56 | 07L << 48 | 04L << 40 | 05L << 32 | 02L << 24 | 03L << 16 | 00L << 8 | 01L << 0;
|
||||||
const long maskE1 = 14L << 56 | 15L << 48 | 12L << 40 | 13L << 32 | 10L << 24 | 11L << 16 | 08L << 8 | 09L << 0;
|
const long MaskE1 = 14L << 56 | 15L << 48 | 12L << 40 | 13L << 32 | 10L << 24 | 11L << 16 | 08L << 8 | 09L << 0;
|
||||||
|
|
||||||
Operand mask = X86GetScalar(context, maskE0);
|
Operand mask = X86GetScalar(context, MaskE0);
|
||||||
|
|
||||||
mask = EmitVectorInsert(context, mask, Const(maskE1), 1, 3);
|
mask = EmitVectorInsert(context, mask, Const(MaskE1), 1, 3);
|
||||||
|
|
||||||
Operand res = context.AddIntrinsic(Intrinsic.X86Pshufb, n, mask);
|
Operand res = context.AddIntrinsic(Intrinsic.X86Pshufb, n, mask);
|
||||||
|
|
||||||
|
@ -503,21 +503,21 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
if (op.Size == 0)
|
if (op.Size == 0)
|
||||||
{
|
{
|
||||||
const long maskE0 = 04L << 56 | 05L << 48 | 06L << 40 | 07L << 32 | 00L << 24 | 01L << 16 | 02L << 8 | 03L << 0;
|
const long MaskE0 = 04L << 56 | 05L << 48 | 06L << 40 | 07L << 32 | 00L << 24 | 01L << 16 | 02L << 8 | 03L << 0;
|
||||||
const long maskE1 = 12L << 56 | 13L << 48 | 14L << 40 | 15L << 32 | 08L << 24 | 09L << 16 | 10L << 8 | 11L << 0;
|
const long MaskE1 = 12L << 56 | 13L << 48 | 14L << 40 | 15L << 32 | 08L << 24 | 09L << 16 | 10L << 8 | 11L << 0;
|
||||||
|
|
||||||
mask = X86GetScalar(context, maskE0);
|
mask = X86GetScalar(context, MaskE0);
|
||||||
|
|
||||||
mask = EmitVectorInsert(context, mask, Const(maskE1), 1, 3);
|
mask = EmitVectorInsert(context, mask, Const(MaskE1), 1, 3);
|
||||||
}
|
}
|
||||||
else /* if (op.Size == 1) */
|
else /* if (op.Size == 1) */
|
||||||
{
|
{
|
||||||
const long maskE0 = 05L << 56 | 04L << 48 | 07L << 40 | 06L << 32 | 01L << 24 | 00L << 16 | 03L << 8 | 02L << 0;
|
const long MaskE0 = 05L << 56 | 04L << 48 | 07L << 40 | 06L << 32 | 01L << 24 | 00L << 16 | 03L << 8 | 02L << 0;
|
||||||
const long maskE1 = 13L << 56 | 12L << 48 | 15L << 40 | 14L << 32 | 09L << 24 | 08L << 16 | 11L << 8 | 10L << 0;
|
const long MaskE1 = 13L << 56 | 12L << 48 | 15L << 40 | 14L << 32 | 09L << 24 | 08L << 16 | 11L << 8 | 10L << 0;
|
||||||
|
|
||||||
mask = X86GetScalar(context, maskE0);
|
mask = X86GetScalar(context, MaskE0);
|
||||||
|
|
||||||
mask = EmitVectorInsert(context, mask, Const(maskE1), 1, 3);
|
mask = EmitVectorInsert(context, mask, Const(MaskE1), 1, 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
Operand res = context.AddIntrinsic(Intrinsic.X86Pshufb, n, mask);
|
Operand res = context.AddIntrinsic(Intrinsic.X86Pshufb, n, mask);
|
||||||
|
@ -547,30 +547,30 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
if (op.Size == 0)
|
if (op.Size == 0)
|
||||||
{
|
{
|
||||||
const long maskE0 = 00L << 56 | 01L << 48 | 02L << 40 | 03L << 32 | 04L << 24 | 05L << 16 | 06L << 8 | 07L << 0;
|
const long MaskE0 = 00L << 56 | 01L << 48 | 02L << 40 | 03L << 32 | 04L << 24 | 05L << 16 | 06L << 8 | 07L << 0;
|
||||||
const long maskE1 = 08L << 56 | 09L << 48 | 10L << 40 | 11L << 32 | 12L << 24 | 13L << 16 | 14L << 8 | 15L << 0;
|
const long MaskE1 = 08L << 56 | 09L << 48 | 10L << 40 | 11L << 32 | 12L << 24 | 13L << 16 | 14L << 8 | 15L << 0;
|
||||||
|
|
||||||
mask = X86GetScalar(context, maskE0);
|
mask = X86GetScalar(context, MaskE0);
|
||||||
|
|
||||||
mask = EmitVectorInsert(context, mask, Const(maskE1), 1, 3);
|
mask = EmitVectorInsert(context, mask, Const(MaskE1), 1, 3);
|
||||||
}
|
}
|
||||||
else if (op.Size == 1)
|
else if (op.Size == 1)
|
||||||
{
|
{
|
||||||
const long maskE0 = 01L << 56 | 00L << 48 | 03L << 40 | 02L << 32 | 05L << 24 | 04L << 16 | 07L << 8 | 06L << 0;
|
const long MaskE0 = 01L << 56 | 00L << 48 | 03L << 40 | 02L << 32 | 05L << 24 | 04L << 16 | 07L << 8 | 06L << 0;
|
||||||
const long maskE1 = 09L << 56 | 08L << 48 | 11L << 40 | 10L << 32 | 13L << 24 | 12L << 16 | 15L << 8 | 14L << 0;
|
const long MaskE1 = 09L << 56 | 08L << 48 | 11L << 40 | 10L << 32 | 13L << 24 | 12L << 16 | 15L << 8 | 14L << 0;
|
||||||
|
|
||||||
mask = X86GetScalar(context, maskE0);
|
mask = X86GetScalar(context, MaskE0);
|
||||||
|
|
||||||
mask = EmitVectorInsert(context, mask, Const(maskE1), 1, 3);
|
mask = EmitVectorInsert(context, mask, Const(MaskE1), 1, 3);
|
||||||
}
|
}
|
||||||
else /* if (op.Size == 2) */
|
else /* if (op.Size == 2) */
|
||||||
{
|
{
|
||||||
const long maskE0 = 03L << 56 | 02L << 48 | 01L << 40 | 00L << 32 | 07L << 24 | 06L << 16 | 05L << 8 | 04L << 0;
|
const long MaskE0 = 03L << 56 | 02L << 48 | 01L << 40 | 00L << 32 | 07L << 24 | 06L << 16 | 05L << 8 | 04L << 0;
|
||||||
const long maskE1 = 11L << 56 | 10L << 48 | 09L << 40 | 08L << 32 | 15L << 24 | 14L << 16 | 13L << 8 | 12L << 0;
|
const long MaskE1 = 11L << 56 | 10L << 48 | 09L << 40 | 08L << 32 | 15L << 24 | 14L << 16 | 13L << 8 | 12L << 0;
|
||||||
|
|
||||||
mask = X86GetScalar(context, maskE0);
|
mask = X86GetScalar(context, MaskE0);
|
||||||
|
|
||||||
mask = EmitVectorInsert(context, mask, Const(maskE1), 1, 3);
|
mask = EmitVectorInsert(context, mask, Const(MaskE1), 1, 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
Operand res = context.AddIntrinsic(Intrinsic.X86Pshufb, n, mask);
|
Operand res = context.AddIntrinsic(Intrinsic.X86Pshufb, n, mask);
|
||||||
|
|
|
@ -175,10 +175,10 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
public static ushort FPRoundCv(double real, ExecutionContext context)
|
public static ushort FPRoundCv(double real, ExecutionContext context)
|
||||||
{
|
{
|
||||||
const int minimumExp = -14;
|
const int MinimumExp = -14;
|
||||||
|
|
||||||
const int e = 5;
|
const int E = 5;
|
||||||
const int f = 10;
|
const int F = 10;
|
||||||
|
|
||||||
bool sign;
|
bool sign;
|
||||||
double mantissa;
|
double mantissa;
|
||||||
|
@ -208,15 +208,15 @@ namespace ARMeilleure.Instructions
|
||||||
exponent++;
|
exponent++;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint biasedExp = (uint)Math.Max(exponent - minimumExp + 1, 0);
|
uint biasedExp = (uint)Math.Max(exponent - MinimumExp + 1, 0);
|
||||||
|
|
||||||
if (biasedExp == 0u)
|
if (biasedExp == 0u)
|
||||||
{
|
{
|
||||||
mantissa /= Math.Pow(2d, minimumExp - exponent);
|
mantissa /= Math.Pow(2d, MinimumExp - exponent);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint intMant = (uint)Math.Floor(mantissa * Math.Pow(2d, f));
|
uint intMant = (uint)Math.Floor(mantissa * Math.Pow(2d, F));
|
||||||
double error = mantissa * Math.Pow(2d, f) - (double)intMant;
|
double error = mantissa * Math.Pow(2d, F) - (double)intMant;
|
||||||
|
|
||||||
if (biasedExp == 0u && (error != 0d || (context.Fpcr & FPCR.Ufe) != 0))
|
if (biasedExp == 0u && (error != 0d || (context.Fpcr & FPCR.Ufe) != 0))
|
||||||
{
|
{
|
||||||
|
@ -256,12 +256,12 @@ namespace ARMeilleure.Instructions
|
||||||
{
|
{
|
||||||
intMant++;
|
intMant++;
|
||||||
|
|
||||||
if (intMant == 1u << f)
|
if (intMant == 1u << F)
|
||||||
{
|
{
|
||||||
biasedExp = 1u;
|
biasedExp = 1u;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (intMant == 1u << (f + 1))
|
if (intMant == 1u << (F + 1))
|
||||||
{
|
{
|
||||||
biasedExp++;
|
biasedExp++;
|
||||||
intMant >>= 1;
|
intMant >>= 1;
|
||||||
|
@ -272,7 +272,7 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
if ((context.Fpcr & FPCR.Ahp) == 0)
|
if ((context.Fpcr & FPCR.Ahp) == 0)
|
||||||
{
|
{
|
||||||
if (biasedExp >= (1u << e) - 1u)
|
if (biasedExp >= (1u << E) - 1u)
|
||||||
{
|
{
|
||||||
resultBits = overflowToInf ? FPInfinity(sign) : FPMaxNormal(sign);
|
resultBits = overflowToInf ? FPInfinity(sign) : FPMaxNormal(sign);
|
||||||
|
|
||||||
|
@ -287,7 +287,7 @@ namespace ARMeilleure.Instructions
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (biasedExp >= 1u << e)
|
if (biasedExp >= 1u << E)
|
||||||
{
|
{
|
||||||
resultBits = (ushort)((sign ? 1u : 0u) << 15 | 0x7FFFu);
|
resultBits = (ushort)((sign ? 1u : 0u) << 15 | 0x7FFFu);
|
||||||
|
|
||||||
|
@ -354,10 +354,10 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
private static float FPRoundCv(double real, ExecutionContext context)
|
private static float FPRoundCv(double real, ExecutionContext context)
|
||||||
{
|
{
|
||||||
const int minimumExp = -126;
|
const int MinimumExp = -126;
|
||||||
|
|
||||||
const int e = 8;
|
const int E = 8;
|
||||||
const int f = 23;
|
const int F = 23;
|
||||||
|
|
||||||
bool sign;
|
bool sign;
|
||||||
double mantissa;
|
double mantissa;
|
||||||
|
@ -387,22 +387,22 @@ namespace ARMeilleure.Instructions
|
||||||
exponent++;
|
exponent++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((context.Fpcr & FPCR.Fz) != 0 && exponent < minimumExp)
|
if ((context.Fpcr & FPCR.Fz) != 0 && exponent < MinimumExp)
|
||||||
{
|
{
|
||||||
context.Fpsr |= FPSR.Ufc;
|
context.Fpsr |= FPSR.Ufc;
|
||||||
|
|
||||||
return SoftFloat32.FPZero(sign);
|
return SoftFloat32.FPZero(sign);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint biasedExp = (uint)Math.Max(exponent - minimumExp + 1, 0);
|
uint biasedExp = (uint)Math.Max(exponent - MinimumExp + 1, 0);
|
||||||
|
|
||||||
if (biasedExp == 0u)
|
if (biasedExp == 0u)
|
||||||
{
|
{
|
||||||
mantissa /= Math.Pow(2d, minimumExp - exponent);
|
mantissa /= Math.Pow(2d, MinimumExp - exponent);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint intMant = (uint)Math.Floor(mantissa * Math.Pow(2d, f));
|
uint intMant = (uint)Math.Floor(mantissa * Math.Pow(2d, F));
|
||||||
double error = mantissa * Math.Pow(2d, f) - (double)intMant;
|
double error = mantissa * Math.Pow(2d, F) - (double)intMant;
|
||||||
|
|
||||||
if (biasedExp == 0u && (error != 0d || (context.Fpcr & FPCR.Ufe) != 0))
|
if (biasedExp == 0u && (error != 0d || (context.Fpcr & FPCR.Ufe) != 0))
|
||||||
{
|
{
|
||||||
|
@ -442,12 +442,12 @@ namespace ARMeilleure.Instructions
|
||||||
{
|
{
|
||||||
intMant++;
|
intMant++;
|
||||||
|
|
||||||
if (intMant == 1u << f)
|
if (intMant == 1u << F)
|
||||||
{
|
{
|
||||||
biasedExp = 1u;
|
biasedExp = 1u;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (intMant == 1u << (f + 1))
|
if (intMant == 1u << (F + 1))
|
||||||
{
|
{
|
||||||
biasedExp++;
|
biasedExp++;
|
||||||
intMant >>= 1;
|
intMant >>= 1;
|
||||||
|
@ -456,7 +456,7 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
float result;
|
float result;
|
||||||
|
|
||||||
if (biasedExp >= (1u << e) - 1u)
|
if (biasedExp >= (1u << E) - 1u)
|
||||||
{
|
{
|
||||||
result = overflowToInf ? SoftFloat32.FPInfinity(sign) : SoftFloat32.FPMaxNormal(sign);
|
result = overflowToInf ? SoftFloat32.FPInfinity(sign) : SoftFloat32.FPMaxNormal(sign);
|
||||||
|
|
||||||
|
@ -529,10 +529,10 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
private static double FPRoundCv(double real, ExecutionContext context)
|
private static double FPRoundCv(double real, ExecutionContext context)
|
||||||
{
|
{
|
||||||
const int minimumExp = -1022;
|
const int MinimumExp = -1022;
|
||||||
|
|
||||||
const int e = 11;
|
const int E = 11;
|
||||||
const int f = 52;
|
const int F = 52;
|
||||||
|
|
||||||
bool sign;
|
bool sign;
|
||||||
double mantissa;
|
double mantissa;
|
||||||
|
@ -562,22 +562,22 @@ namespace ARMeilleure.Instructions
|
||||||
exponent++;
|
exponent++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((context.Fpcr & FPCR.Fz) != 0 && exponent < minimumExp)
|
if ((context.Fpcr & FPCR.Fz) != 0 && exponent < MinimumExp)
|
||||||
{
|
{
|
||||||
context.Fpsr |= FPSR.Ufc;
|
context.Fpsr |= FPSR.Ufc;
|
||||||
|
|
||||||
return SoftFloat64.FPZero(sign);
|
return SoftFloat64.FPZero(sign);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint biasedExp = (uint)Math.Max(exponent - minimumExp + 1, 0);
|
uint biasedExp = (uint)Math.Max(exponent - MinimumExp + 1, 0);
|
||||||
|
|
||||||
if (biasedExp == 0u)
|
if (biasedExp == 0u)
|
||||||
{
|
{
|
||||||
mantissa /= Math.Pow(2d, minimumExp - exponent);
|
mantissa /= Math.Pow(2d, MinimumExp - exponent);
|
||||||
}
|
}
|
||||||
|
|
||||||
ulong intMant = (ulong)Math.Floor(mantissa * Math.Pow(2d, f));
|
ulong intMant = (ulong)Math.Floor(mantissa * Math.Pow(2d, F));
|
||||||
double error = mantissa * Math.Pow(2d, f) - (double)intMant;
|
double error = mantissa * Math.Pow(2d, F) - (double)intMant;
|
||||||
|
|
||||||
if (biasedExp == 0u && (error != 0d || (context.Fpcr & FPCR.Ufe) != 0))
|
if (biasedExp == 0u && (error != 0d || (context.Fpcr & FPCR.Ufe) != 0))
|
||||||
{
|
{
|
||||||
|
@ -617,12 +617,12 @@ namespace ARMeilleure.Instructions
|
||||||
{
|
{
|
||||||
intMant++;
|
intMant++;
|
||||||
|
|
||||||
if (intMant == 1ul << f)
|
if (intMant == 1ul << F)
|
||||||
{
|
{
|
||||||
biasedExp = 1u;
|
biasedExp = 1u;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (intMant == 1ul << (f + 1))
|
if (intMant == 1ul << (F + 1))
|
||||||
{
|
{
|
||||||
biasedExp++;
|
biasedExp++;
|
||||||
intMant >>= 1;
|
intMant >>= 1;
|
||||||
|
@ -631,7 +631,7 @@ namespace ARMeilleure.Instructions
|
||||||
|
|
||||||
double result;
|
double result;
|
||||||
|
|
||||||
if (biasedExp >= (1u << e) - 1u)
|
if (biasedExp >= (1u << E) - 1u)
|
||||||
{
|
{
|
||||||
result = overflowToInf ? SoftFloat64.FPInfinity(sign) : SoftFloat64.FPMaxNormal(sign);
|
result = overflowToInf ? SoftFloat64.FPInfinity(sign) : SoftFloat64.FPMaxNormal(sign);
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@ using ARMeilleure.Translation.Cache;
|
||||||
using System;
|
using System;
|
||||||
using System.Runtime.CompilerServices;
|
using System.Runtime.CompilerServices;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
using static ARMeilleure.IntermediateRepresentation.Operand.Factory;
|
using static ARMeilleure.IntermediateRepresentation.Operand.Factory;
|
||||||
|
|
||||||
namespace ARMeilleure.Signal
|
namespace ARMeilleure.Signal
|
||||||
|
@ -261,20 +260,20 @@ namespace ARMeilleure.Signal
|
||||||
{
|
{
|
||||||
if (OperatingSystem.IsMacOS())
|
if (OperatingSystem.IsMacOS())
|
||||||
{
|
{
|
||||||
const ulong mcontextOffset = 48; // uc_mcontext
|
const ulong McontextOffset = 48; // uc_mcontext
|
||||||
Operand ctxPtr = context.Load(OperandType.I64, context.Add(ucontextPtr, Const(mcontextOffset)));
|
Operand ctxPtr = context.Load(OperandType.I64, context.Add(ucontextPtr, Const(McontextOffset)));
|
||||||
|
|
||||||
if (RuntimeInformation.ProcessArchitecture == Architecture.Arm64)
|
if (RuntimeInformation.ProcessArchitecture == Architecture.Arm64)
|
||||||
{
|
{
|
||||||
const ulong esrOffset = 8; // __es.__esr
|
const ulong EsrOffset = 8; // __es.__esr
|
||||||
Operand esr = context.Load(OperandType.I64, context.Add(ctxPtr, Const(esrOffset)));
|
Operand esr = context.Load(OperandType.I64, context.Add(ctxPtr, Const(EsrOffset)));
|
||||||
return context.BitwiseAnd(esr, Const(0x40ul));
|
return context.BitwiseAnd(esr, Const(0x40ul));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (RuntimeInformation.ProcessArchitecture == Architecture.X64)
|
if (RuntimeInformation.ProcessArchitecture == Architecture.X64)
|
||||||
{
|
{
|
||||||
const ulong errOffset = 4; // __es.__err
|
const ulong ErrOffset = 4; // __es.__err
|
||||||
Operand err = context.Load(OperandType.I64, context.Add(ctxPtr, Const(errOffset)));
|
Operand err = context.Load(OperandType.I64, context.Add(ctxPtr, Const(ErrOffset)));
|
||||||
return context.BitwiseAnd(err, Const(2ul));
|
return context.BitwiseAnd(err, Const(2ul));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -287,10 +286,10 @@ namespace ARMeilleure.Signal
|
||||||
Operand loopLabel = Label();
|
Operand loopLabel = Label();
|
||||||
Operand successLabel = Label();
|
Operand successLabel = Label();
|
||||||
|
|
||||||
const ulong auxOffset = 464; // uc_mcontext.__reserved
|
const ulong AuxOffset = 464; // uc_mcontext.__reserved
|
||||||
const uint esrMagic = 0x45535201;
|
const uint EsrMagic = 0x45535201;
|
||||||
|
|
||||||
context.Copy(auxPtr, context.Add(ucontextPtr, Const(auxOffset)));
|
context.Copy(auxPtr, context.Add(ucontextPtr, Const(AuxOffset)));
|
||||||
|
|
||||||
context.MarkLabel(loopLabel);
|
context.MarkLabel(loopLabel);
|
||||||
|
|
||||||
|
@ -299,7 +298,7 @@ namespace ARMeilleure.Signal
|
||||||
// _aarch64_ctx::size
|
// _aarch64_ctx::size
|
||||||
Operand size = context.Load(OperandType.I32, context.Add(auxPtr, Const(4ul)));
|
Operand size = context.Load(OperandType.I32, context.Add(auxPtr, Const(4ul)));
|
||||||
|
|
||||||
context.BranchIf(successLabel, magic, Const(esrMagic), Comparison.Equal);
|
context.BranchIf(successLabel, magic, Const(EsrMagic), Comparison.Equal);
|
||||||
|
|
||||||
context.Copy(auxPtr, context.Add(auxPtr, context.ZeroExtend32(OperandType.I64, size)));
|
context.Copy(auxPtr, context.Add(auxPtr, context.ZeroExtend32(OperandType.I64, size)));
|
||||||
|
|
||||||
|
@ -314,8 +313,8 @@ namespace ARMeilleure.Signal
|
||||||
|
|
||||||
if (RuntimeInformation.ProcessArchitecture == Architecture.X64)
|
if (RuntimeInformation.ProcessArchitecture == Architecture.X64)
|
||||||
{
|
{
|
||||||
const int errOffset = 192; // uc_mcontext.gregs[REG_ERR]
|
const int ErrOffset = 192; // uc_mcontext.gregs[REG_ERR]
|
||||||
Operand err = context.Load(OperandType.I64, context.Add(ucontextPtr, Const(errOffset)));
|
Operand err = context.Load(OperandType.I64, context.Add(ucontextPtr, Const(ErrOffset)));
|
||||||
return context.BitwiseAnd(err, Const(2ul));
|
return context.BitwiseAnd(err, Const(2ul));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -880,7 +880,7 @@ namespace ARMeilleure.Translation.PTC
|
||||||
|
|
||||||
private void ReportProgress(object state)
|
private void ReportProgress(object state)
|
||||||
{
|
{
|
||||||
const int refreshRate = 50; // ms.
|
const int RefreshRate = 50; // ms.
|
||||||
|
|
||||||
AutoResetEvent endEvent = (AutoResetEvent)state;
|
AutoResetEvent endEvent = (AutoResetEvent)state;
|
||||||
|
|
||||||
|
@ -896,7 +896,7 @@ namespace ARMeilleure.Translation.PTC
|
||||||
count = newCount;
|
count = newCount;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while (!endEvent.WaitOne(refreshRate));
|
while (!endEvent.WaitOne(RefreshRate));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Hash128 ComputeHash(IMemoryManager memory, ulong address, ulong guestSize)
|
public static Hash128 ComputeHash(IMemoryManager memory, ulong address, ulong guestSize)
|
||||||
|
|
|
@ -43,7 +43,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
|
|
||||||
public void Process(CommandList context)
|
public void Process(CommandList context)
|
||||||
{
|
{
|
||||||
const int targetChannelCount = 2;
|
const int TargetChannelCount = 2;
|
||||||
|
|
||||||
ulong currentOffset = CurrentOffset;
|
ulong currentOffset = CurrentOffset;
|
||||||
|
|
||||||
|
@ -59,10 +59,10 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
|
|
||||||
for (int y = 0; y < context.SampleCount; y++)
|
for (int y = 0; y < context.SampleCount; y++)
|
||||||
{
|
{
|
||||||
context.MemoryManager.Write(targetOffset + (ulong)y * targetChannelCount, PcmHelper.Saturate(inputBuffer[y]));
|
context.MemoryManager.Write(targetOffset + (ulong)y * TargetChannelCount, PcmHelper.Saturate(inputBuffer[y]));
|
||||||
}
|
}
|
||||||
|
|
||||||
currentOffset += context.SampleCount * targetChannelCount;
|
currentOffset += context.SampleCount * TargetChannelCount;
|
||||||
|
|
||||||
if (currentOffset >= CircularBufferSize)
|
if (currentOffset >= CircularBufferSize)
|
||||||
{
|
{
|
||||||
|
@ -73,4 +73,4 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
[MethodImpl(MethodImplOptions.AggressiveInlining | MethodImplOptions.AggressiveOptimization)]
|
[MethodImpl(MethodImplOptions.AggressiveInlining | MethodImplOptions.AggressiveOptimization)]
|
||||||
private unsafe void ProcessDelayMono(ref DelayState state, float* outputBuffer, float* inputBuffer, uint sampleCount)
|
private unsafe void ProcessDelayMono(ref DelayState state, float* outputBuffer, float* inputBuffer, uint sampleCount)
|
||||||
{
|
{
|
||||||
const ushort channelCount = 1;
|
const ushort ChannelCount = 1;
|
||||||
|
|
||||||
float feedbackGain = FixedPointHelper.ToFloat(Parameter.FeedbackGain, FixedPointPrecision);
|
float feedbackGain = FixedPointHelper.ToFloat(Parameter.FeedbackGain, FixedPointPrecision);
|
||||||
float inGain = FixedPointHelper.ToFloat(Parameter.InGain, FixedPointPrecision);
|
float inGain = FixedPointHelper.ToFloat(Parameter.InGain, FixedPointPrecision);
|
||||||
|
@ -70,7 +70,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
|
|
||||||
float temp = input * inGain + delayLineValue * feedbackGain;
|
float temp = input * inGain + delayLineValue * feedbackGain;
|
||||||
|
|
||||||
state.UpdateLowPassFilter(ref temp, channelCount);
|
state.UpdateLowPassFilter(ref temp, ChannelCount);
|
||||||
|
|
||||||
outputBuffer[i] = (input * dryGain + delayLineValue * outGain) / 64;
|
outputBuffer[i] = (input * dryGain + delayLineValue * outGain) / 64;
|
||||||
}
|
}
|
||||||
|
@ -79,7 +79,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
[MethodImpl(MethodImplOptions.AggressiveInlining | MethodImplOptions.AggressiveOptimization)]
|
[MethodImpl(MethodImplOptions.AggressiveInlining | MethodImplOptions.AggressiveOptimization)]
|
||||||
private unsafe void ProcessDelayStereo(ref DelayState state, Span<IntPtr> outputBuffers, ReadOnlySpan<IntPtr> inputBuffers, uint sampleCount)
|
private unsafe void ProcessDelayStereo(ref DelayState state, Span<IntPtr> outputBuffers, ReadOnlySpan<IntPtr> inputBuffers, uint sampleCount)
|
||||||
{
|
{
|
||||||
const ushort channelCount = 2;
|
const ushort ChannelCount = 2;
|
||||||
|
|
||||||
float delayFeedbackBaseGain = state.DelayFeedbackBaseGain;
|
float delayFeedbackBaseGain = state.DelayFeedbackBaseGain;
|
||||||
float delayFeedbackCrossGain = state.DelayFeedbackCrossGain;
|
float delayFeedbackCrossGain = state.DelayFeedbackCrossGain;
|
||||||
|
@ -106,7 +106,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
|
|
||||||
Vector2 temp = MatrixHelper.Transform(ref delayLineValues, ref delayFeedback) + channelInput * inGain;
|
Vector2 temp = MatrixHelper.Transform(ref delayLineValues, ref delayFeedback) + channelInput * inGain;
|
||||||
|
|
||||||
state.UpdateLowPassFilter(ref Unsafe.As<Vector2, float>(ref temp), channelCount);
|
state.UpdateLowPassFilter(ref Unsafe.As<Vector2, float>(ref temp), ChannelCount);
|
||||||
|
|
||||||
*((float*)outputBuffers[0] + i) = (channelInput.X * dryGain + delayLineValues.X * outGain) / 64;
|
*((float*)outputBuffers[0] + i) = (channelInput.X * dryGain + delayLineValues.X * outGain) / 64;
|
||||||
*((float*)outputBuffers[1] + i) = (channelInput.Y * dryGain + delayLineValues.Y * outGain) / 64;
|
*((float*)outputBuffers[1] + i) = (channelInput.Y * dryGain + delayLineValues.Y * outGain) / 64;
|
||||||
|
@ -116,7 +116,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
[MethodImpl(MethodImplOptions.AggressiveInlining | MethodImplOptions.AggressiveOptimization)]
|
[MethodImpl(MethodImplOptions.AggressiveInlining | MethodImplOptions.AggressiveOptimization)]
|
||||||
private unsafe void ProcessDelayQuadraphonic(ref DelayState state, Span<IntPtr> outputBuffers, ReadOnlySpan<IntPtr> inputBuffers, uint sampleCount)
|
private unsafe void ProcessDelayQuadraphonic(ref DelayState state, Span<IntPtr> outputBuffers, ReadOnlySpan<IntPtr> inputBuffers, uint sampleCount)
|
||||||
{
|
{
|
||||||
const ushort channelCount = 4;
|
const ushort ChannelCount = 4;
|
||||||
|
|
||||||
float delayFeedbackBaseGain = state.DelayFeedbackBaseGain;
|
float delayFeedbackBaseGain = state.DelayFeedbackBaseGain;
|
||||||
float delayFeedbackCrossGain = state.DelayFeedbackCrossGain;
|
float delayFeedbackCrossGain = state.DelayFeedbackCrossGain;
|
||||||
|
@ -150,7 +150,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
|
|
||||||
Vector4 temp = MatrixHelper.Transform(ref delayLineValues, ref delayFeedback) + channelInput * inGain;
|
Vector4 temp = MatrixHelper.Transform(ref delayLineValues, ref delayFeedback) + channelInput * inGain;
|
||||||
|
|
||||||
state.UpdateLowPassFilter(ref Unsafe.As<Vector4, float>(ref temp), channelCount);
|
state.UpdateLowPassFilter(ref Unsafe.As<Vector4, float>(ref temp), ChannelCount);
|
||||||
|
|
||||||
*((float*)outputBuffers[0] + i) = (channelInput.X * dryGain + delayLineValues.X * outGain) / 64;
|
*((float*)outputBuffers[0] + i) = (channelInput.X * dryGain + delayLineValues.X * outGain) / 64;
|
||||||
*((float*)outputBuffers[1] + i) = (channelInput.Y * dryGain + delayLineValues.Y * outGain) / 64;
|
*((float*)outputBuffers[1] + i) = (channelInput.Y * dryGain + delayLineValues.Y * outGain) / 64;
|
||||||
|
@ -162,7 +162,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
[MethodImpl(MethodImplOptions.AggressiveInlining | MethodImplOptions.AggressiveOptimization)]
|
[MethodImpl(MethodImplOptions.AggressiveInlining | MethodImplOptions.AggressiveOptimization)]
|
||||||
private unsafe void ProcessDelaySurround(ref DelayState state, Span<IntPtr> outputBuffers, ReadOnlySpan<IntPtr> inputBuffers, uint sampleCount)
|
private unsafe void ProcessDelaySurround(ref DelayState state, Span<IntPtr> outputBuffers, ReadOnlySpan<IntPtr> inputBuffers, uint sampleCount)
|
||||||
{
|
{
|
||||||
const ushort channelCount = 6;
|
const ushort ChannelCount = 6;
|
||||||
|
|
||||||
float feedbackGain = FixedPointHelper.ToFloat(Parameter.FeedbackGain, FixedPointPrecision);
|
float feedbackGain = FixedPointHelper.ToFloat(Parameter.FeedbackGain, FixedPointPrecision);
|
||||||
float delayFeedbackBaseGain = state.DelayFeedbackBaseGain;
|
float delayFeedbackBaseGain = state.DelayFeedbackBaseGain;
|
||||||
|
@ -202,7 +202,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
|
|
||||||
Vector6 temp = MatrixHelper.Transform(ref delayLineValues, ref delayFeedback) + channelInput * inGain;
|
Vector6 temp = MatrixHelper.Transform(ref delayLineValues, ref delayFeedback) + channelInput * inGain;
|
||||||
|
|
||||||
state.UpdateLowPassFilter(ref Unsafe.As<Vector6, float>(ref temp), channelCount);
|
state.UpdateLowPassFilter(ref Unsafe.As<Vector6, float>(ref temp), ChannelCount);
|
||||||
|
|
||||||
*((float*)outputBuffers[0] + i) = (channelInput.X * dryGain + delayLineValues.X * outGain) / 64;
|
*((float*)outputBuffers[0] + i) = (channelInput.X * dryGain + delayLineValues.X * outGain) / 64;
|
||||||
*((float*)outputBuffers[1] + i) = (channelInput.Y * dryGain + delayLineValues.Y * outGain) / 64;
|
*((float*)outputBuffers[1] + i) = (channelInput.Y * dryGain + delayLineValues.Y * outGain) / 64;
|
||||||
|
@ -277,4 +277,4 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
ProcessDelay(context, ref state);
|
ProcessDelay(context, ref state);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,7 +65,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
int channelCount = (int)device.GetChannelCount();
|
int channelCount = (int)device.GetChannelCount();
|
||||||
uint bufferCount = Math.Min(device.GetChannelCount(), InputCount);
|
uint bufferCount = Math.Min(device.GetChannelCount(), InputCount);
|
||||||
|
|
||||||
const int sampleCount = Constants.TargetSampleCount;
|
const int SampleCount = Constants.TargetSampleCount;
|
||||||
|
|
||||||
uint inputCount;
|
uint inputCount;
|
||||||
|
|
||||||
|
@ -79,13 +79,13 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
inputCount = bufferCount;
|
inputCount = bufferCount;
|
||||||
}
|
}
|
||||||
|
|
||||||
short[] outputBuffer = new short[inputCount * sampleCount];
|
short[] outputBuffer = new short[inputCount * SampleCount];
|
||||||
|
|
||||||
for (int i = 0; i < bufferCount; i++)
|
for (int i = 0; i < bufferCount; i++)
|
||||||
{
|
{
|
||||||
ReadOnlySpan<float> inputBuffer = GetBuffer(InputBufferIndices[i], sampleCount);
|
ReadOnlySpan<float> inputBuffer = GetBuffer(InputBufferIndices[i], SampleCount);
|
||||||
|
|
||||||
for (int j = 0; j < sampleCount; j++)
|
for (int j = 0; j < SampleCount; j++)
|
||||||
{
|
{
|
||||||
outputBuffer[i + j * channelCount] = PcmHelper.Saturate(inputBuffer[j]);
|
outputBuffer[i + j * channelCount] = PcmHelper.Saturate(inputBuffer[j]);
|
||||||
}
|
}
|
||||||
|
@ -100,4 +100,4 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -96,7 +96,7 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
|
|
||||||
private unsafe void ProcessReverb3dGeneric(ref Reverb3dState state, ReadOnlySpan<IntPtr> outputBuffers, ReadOnlySpan<IntPtr> inputBuffers, uint sampleCount, ReadOnlySpan<int> outputEarlyIndicesTable, ReadOnlySpan<int> targetEarlyDelayLineIndicesTable, ReadOnlySpan<int> targetOutputFeedbackIndicesTable)
|
private unsafe void ProcessReverb3dGeneric(ref Reverb3dState state, ReadOnlySpan<IntPtr> outputBuffers, ReadOnlySpan<IntPtr> inputBuffers, uint sampleCount, ReadOnlySpan<int> outputEarlyIndicesTable, ReadOnlySpan<int> targetEarlyDelayLineIndicesTable, ReadOnlySpan<int> targetOutputFeedbackIndicesTable)
|
||||||
{
|
{
|
||||||
const int delayLineSampleIndexOffset = 1;
|
const int DelayLineSampleIndexOffset = 1;
|
||||||
|
|
||||||
bool isMono = Parameter.ChannelCount == 1;
|
bool isMono = Parameter.ChannelCount == 1;
|
||||||
bool isSurround = Parameter.ChannelCount == 6;
|
bool isSurround = Parameter.ChannelCount == 6;
|
||||||
|
@ -111,14 +111,14 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
{
|
{
|
||||||
outputValues.Fill(0);
|
outputValues.Fill(0);
|
||||||
|
|
||||||
float tapOut = state.PreDelayLine.TapUnsafe(state.ReflectionDelayTime, delayLineSampleIndexOffset);
|
float tapOut = state.PreDelayLine.TapUnsafe(state.ReflectionDelayTime, DelayLineSampleIndexOffset);
|
||||||
|
|
||||||
for (int i = 0; i < targetEarlyDelayLineIndicesTable.Length; i++)
|
for (int i = 0; i < targetEarlyDelayLineIndicesTable.Length; i++)
|
||||||
{
|
{
|
||||||
int earlyDelayIndex = targetEarlyDelayLineIndicesTable[i];
|
int earlyDelayIndex = targetEarlyDelayLineIndicesTable[i];
|
||||||
int outputIndex = outputEarlyIndicesTable[earlyDelayIndex];
|
int outputIndex = outputEarlyIndicesTable[earlyDelayIndex];
|
||||||
|
|
||||||
float tempTapOut = state.PreDelayLine.TapUnsafe(state.EarlyDelayTime[earlyDelayIndex], delayLineSampleIndexOffset);
|
float tempTapOut = state.PreDelayLine.TapUnsafe(state.EarlyDelayTime[earlyDelayIndex], DelayLineSampleIndexOffset);
|
||||||
|
|
||||||
outputValues[outputIndex] += tempTapOut * state.EarlyGain[earlyDelayIndex];
|
outputValues[outputIndex] += tempTapOut * state.EarlyGain[earlyDelayIndex];
|
||||||
}
|
}
|
||||||
|
@ -251,4 +251,4 @@ namespace Ryujinx.Audio.Renderer.Dsp.Command
|
||||||
ProcessReverb3d(context, ref state);
|
ProcessReverb3d(context, ref state);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,9 +44,9 @@ namespace Ryujinx.Audio.Renderer.Dsp
|
||||||
|
|
||||||
public static void ProcessWaveBuffers(IVirtualMemoryManager memoryManager, Span<float> outputBuffer, ref WaveBufferInformation info, Span<WaveBuffer> wavebuffers, ref VoiceUpdateState voiceState, uint targetSampleRate, int sampleCount)
|
public static void ProcessWaveBuffers(IVirtualMemoryManager memoryManager, Span<float> outputBuffer, ref WaveBufferInformation info, Span<WaveBuffer> wavebuffers, ref VoiceUpdateState voiceState, uint targetSampleRate, int sampleCount)
|
||||||
{
|
{
|
||||||
const int tempBufferSize = 0x3F00;
|
const int TempBufferSize = 0x3F00;
|
||||||
|
|
||||||
Span<short> tempBuffer = stackalloc short[tempBufferSize];
|
Span<short> tempBuffer = stackalloc short[TempBufferSize];
|
||||||
|
|
||||||
float sampleRateRatio = (float)info.SourceSampleRate / targetSampleRate * info.Pitch;
|
float sampleRateRatio = (float)info.SourceSampleRate / targetSampleRate * info.Pitch;
|
||||||
|
|
||||||
|
@ -60,11 +60,11 @@ namespace Ryujinx.Audio.Renderer.Dsp
|
||||||
|
|
||||||
int totalNeededSize = (int)MathF.Truncate(fraction + sampleRateRatio * sampleCount);
|
int totalNeededSize = (int)MathF.Truncate(fraction + sampleRateRatio * sampleCount);
|
||||||
|
|
||||||
if (totalNeededSize + pitchMaxLength <= tempBufferSize && totalNeededSize >= 0)
|
if (totalNeededSize + pitchMaxLength <= TempBufferSize && totalNeededSize >= 0)
|
||||||
{
|
{
|
||||||
int sourceSampleCountToProcess = sampleCount;
|
int sourceSampleCountToProcess = sampleCount;
|
||||||
|
|
||||||
int maxSampleCountPerIteration = Math.Min((int)MathF.Truncate((tempBufferSize - fraction) / sampleRateRatio), sampleCount);
|
int maxSampleCountPerIteration = Math.Min((int)MathF.Truncate((TempBufferSize - fraction) / sampleRateRatio), sampleCount);
|
||||||
|
|
||||||
bool isStarving = false;
|
bool isStarving = false;
|
||||||
|
|
||||||
|
@ -463,4 +463,4 @@ namespace Ryujinx.Audio.Renderer.Dsp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,13 +32,13 @@ namespace Ryujinx.Audio.Renderer.Dsp
|
||||||
|
|
||||||
float BlackmanWindow(float x)
|
float BlackmanWindow(float x)
|
||||||
{
|
{
|
||||||
const float a = 0.18f;
|
const float A = 0.18f;
|
||||||
const float a0 = 0.5f - 0.5f * a;
|
const float A0 = 0.5f - 0.5f * A;
|
||||||
const float a1 = -0.5f;
|
const float A1 = -0.5f;
|
||||||
const float a2 = 0.5f * a;
|
const float A2 = 0.5f * A;
|
||||||
return a0 + a1 * MathF.Cos(2 * MathF.PI * x) + a2 * MathF.Cos(4 * MathF.PI * x);
|
return A0 + A1 * MathF.Cos(2 * MathF.PI * x) + A2 * MathF.Cos(4 * MathF.PI * x);
|
||||||
}
|
}
|
||||||
|
|
||||||
Array20<float> result = new Array20<float>();
|
Array20<float> result = new Array20<float>();
|
||||||
|
|
||||||
for (int i = 0; i < FilterBankLength; i++)
|
for (int i = 0; i < FilterBankLength; i++)
|
||||||
|
@ -112,7 +112,7 @@ namespace Ryujinx.Audio.Renderer.Dsp
|
||||||
int inputBufferIndex = 0;
|
int inputBufferIndex = 0;
|
||||||
|
|
||||||
switch (state.Scale)
|
switch (state.Scale)
|
||||||
{
|
{
|
||||||
case 6.0f:
|
case 6.0f:
|
||||||
for (int i = 0; i < outputSampleCount; i++)
|
for (int i = 0; i < outputSampleCount; i++)
|
||||||
{
|
{
|
||||||
|
@ -189,4 +189,4 @@ namespace Ryujinx.Audio.Renderer.Dsp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,7 +60,7 @@ namespace Ryujinx.Audio.Renderer.Server
|
||||||
|
|
||||||
public uint Estimate(MixRampGroupedCommand command)
|
public uint Estimate(MixRampGroupedCommand command)
|
||||||
{
|
{
|
||||||
const float costPerSample = 7.245f;
|
const float CostPerSample = 7.245f;
|
||||||
|
|
||||||
Debug.Assert(_sampleCount == 160 || _sampleCount == 240);
|
Debug.Assert(_sampleCount == 160 || _sampleCount == 240);
|
||||||
|
|
||||||
|
@ -74,7 +74,7 @@ namespace Ryujinx.Audio.Renderer.Server
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return (uint)(_sampleCount * costPerSample * volumeCount);
|
return (uint)(_sampleCount * CostPerSample * volumeCount);
|
||||||
}
|
}
|
||||||
|
|
||||||
public uint Estimate(MixRampCommand command)
|
public uint Estimate(MixRampCommand command)
|
||||||
|
@ -549,4 +549,4 @@ namespace Ryujinx.Audio.Renderer.Server
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -256,19 +256,19 @@ namespace Ryujinx.Audio.Renderer.Server.MemoryPool
|
||||||
|
|
||||||
MemoryPoolUserState outputState;
|
MemoryPoolUserState outputState;
|
||||||
|
|
||||||
const uint pageSize = 0x1000;
|
const uint PageSize = 0x1000;
|
||||||
|
|
||||||
if (inputState != MemoryPoolUserState.RequestAttach && inputState != MemoryPoolUserState.RequestDetach)
|
if (inputState != MemoryPoolUserState.RequestAttach && inputState != MemoryPoolUserState.RequestDetach)
|
||||||
{
|
{
|
||||||
return UpdateResult.Success;
|
return UpdateResult.Success;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (inParameter.CpuAddress == 0 || (inParameter.CpuAddress % pageSize) != 0)
|
if (inParameter.CpuAddress == 0 || (inParameter.CpuAddress % PageSize) != 0)
|
||||||
{
|
{
|
||||||
return UpdateResult.InvalidParameter;
|
return UpdateResult.InvalidParameter;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (inParameter.Size == 0 || (inParameter.Size % pageSize) != 0)
|
if (inParameter.Size == 0 || (inParameter.Size % PageSize) != 0)
|
||||||
{
|
{
|
||||||
return UpdateResult.InvalidParameter;
|
return UpdateResult.InvalidParameter;
|
||||||
}
|
}
|
||||||
|
@ -363,4 +363,4 @@ namespace Ryujinx.Audio.Renderer.Server.MemoryPool
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,8 +10,8 @@ using Ryujinx.Ava.UI.Helpers;
|
||||||
using Ryujinx.Ava.UI.ViewModels;
|
using Ryujinx.Ava.UI.ViewModels;
|
||||||
using Ryujinx.Ava.UI.Windows;
|
using Ryujinx.Ava.UI.Windows;
|
||||||
using Ryujinx.Common.Configuration;
|
using Ryujinx.Common.Configuration;
|
||||||
using Ryujinx.Ui.App.Common;
|
|
||||||
using Ryujinx.HLE.HOS;
|
using Ryujinx.HLE.HOS;
|
||||||
|
using Ryujinx.Ui.App.Common;
|
||||||
using Ryujinx.Ui.Common.Helper;
|
using Ryujinx.Ui.Common.Helper;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
|
@ -40,9 +40,9 @@ namespace Ryujinx.Ava.UI.Models
|
||||||
|
|
||||||
private string GetSizeString()
|
private string GetSizeString()
|
||||||
{
|
{
|
||||||
const int scale = 1024;
|
const int Scale = 1024;
|
||||||
string[] orders = { "GiB", "MiB", "KiB" };
|
string[] orders = { "GiB", "MiB", "KiB" };
|
||||||
long max = (long)Math.Pow(scale, orders.Length);
|
long max = (long)Math.Pow(Scale, orders.Length);
|
||||||
|
|
||||||
foreach (string order in orders)
|
foreach (string order in orders)
|
||||||
{
|
{
|
||||||
|
@ -51,7 +51,7 @@ namespace Ryujinx.Ava.UI.Models
|
||||||
return $"{decimal.Divide(Size, max):##.##} {order}";
|
return $"{decimal.Divide(Size, max):##.##} {order}";
|
||||||
}
|
}
|
||||||
|
|
||||||
max /= scale;
|
max /= Scale;
|
||||||
}
|
}
|
||||||
|
|
||||||
return "0 KiB";
|
return "0 KiB";
|
||||||
|
@ -109,4 +109,4 @@ namespace Ryujinx.Ava.UI.Models
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -622,7 +622,7 @@ namespace Ryujinx.Ava.UI.ViewModels
|
||||||
OnPropertyChanged();
|
OnPropertyChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public double WindowWidth
|
public double WindowWidth
|
||||||
{
|
{
|
||||||
get => _windowWidth;
|
get => _windowWidth;
|
||||||
|
@ -1124,13 +1124,13 @@ namespace Ryujinx.Ava.UI.ViewModels
|
||||||
|
|
||||||
var dominantColor = IconColorPicker.GetFilteredColor(gameIconBmp).ToPixel<Bgra32>();
|
var dominantColor = IconColorPicker.GetFilteredColor(gameIconBmp).ToPixel<Bgra32>();
|
||||||
|
|
||||||
const float colorMultiple = 0.5f;
|
const float ColorMultiple = 0.5f;
|
||||||
|
|
||||||
Color progressFgColor = Color.FromRgb(dominantColor.R, dominantColor.G, dominantColor.B);
|
Color progressFgColor = Color.FromRgb(dominantColor.R, dominantColor.G, dominantColor.B);
|
||||||
Color progressBgColor = Color.FromRgb(
|
Color progressBgColor = Color.FromRgb(
|
||||||
(byte)(dominantColor.R * colorMultiple),
|
(byte)(dominantColor.R * ColorMultiple),
|
||||||
(byte)(dominantColor.G * colorMultiple),
|
(byte)(dominantColor.G * ColorMultiple),
|
||||||
(byte)(dominantColor.B * colorMultiple));
|
(byte)(dominantColor.B * ColorMultiple));
|
||||||
|
|
||||||
ProgressBarForegroundColor = new SolidColorBrush(progressFgColor);
|
ProgressBarForegroundColor = new SolidColorBrush(progressFgColor);
|
||||||
ProgressBarBackgroundColor = new SolidColorBrush(progressBgColor);
|
ProgressBarBackgroundColor = new SolidColorBrush(progressBgColor);
|
||||||
|
@ -1677,4 +1677,4 @@ namespace Ryujinx.Ava.UI.ViewModels
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,14 +18,14 @@ using Ryujinx.HLE.FileSystem;
|
||||||
using Ryujinx.HLE.HOS.Services.Time.TimeZone;
|
using Ryujinx.HLE.HOS.Services.Time.TimeZone;
|
||||||
using Ryujinx.Ui.Common.Configuration;
|
using Ryujinx.Ui.Common.Configuration;
|
||||||
using Ryujinx.Ui.Common.Configuration.System;
|
using Ryujinx.Ui.Common.Configuration.System;
|
||||||
|
using Silk.NET.Vulkan;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Collections.ObjectModel;
|
using System.Collections.ObjectModel;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Runtime.InteropServices;
|
|
||||||
using System.Net.NetworkInformation;
|
using System.Net.NetworkInformation;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
using TimeZone = Ryujinx.Ava.UI.Models.TimeZone;
|
using TimeZone = Ryujinx.Ava.UI.Models.TimeZone;
|
||||||
using Silk.NET.Vulkan;
|
|
||||||
|
|
||||||
namespace Ryujinx.Ava.UI.ViewModels
|
namespace Ryujinx.Ava.UI.ViewModels
|
||||||
{
|
{
|
||||||
|
|
|
@ -44,10 +44,10 @@ namespace Ryujinx.Common.SystemInfo
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
const int flavor = 4; // HOST_VM_INFO64
|
const int Flavor = 4; // HOST_VM_INFO64
|
||||||
uint count = (uint)(Marshal.SizeOf<VMStatistics64>() / sizeof(int)); // HOST_VM_INFO64_COUNT
|
uint count = (uint)(Marshal.SizeOf<VMStatistics64>() / sizeof(int)); // HOST_VM_INFO64_COUNT
|
||||||
VMStatistics64 stats = new();
|
VMStatistics64 stats = new();
|
||||||
result = host_statistics64(port, flavor, ref stats, ref count);
|
result = host_statistics64(port, Flavor, ref stats, ref count);
|
||||||
|
|
||||||
if (result != 0)
|
if (result != 0)
|
||||||
{
|
{
|
||||||
|
@ -154,4 +154,4 @@ namespace Ryujinx.Common.SystemInfo
|
||||||
[LibraryImport(SystemLibraryName, SetLastError = true)]
|
[LibraryImport(SystemLibraryName, SetLastError = true)]
|
||||||
private static partial int host_statistics64(uint host_priv, int host_flavor, ref VMStatistics64 host_info64_out, ref uint host_info64_outCnt);
|
private static partial int host_statistics64(uint host_priv, int host_flavor, ref VMStatistics64 host_info64_out, ref uint host_info64_outCnt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,10 +29,10 @@ namespace Ryujinx.Common.SystemInterop
|
||||||
[SupportedOSPlatform("macos")]
|
[SupportedOSPlatform("macos")]
|
||||||
private void RegisterPosix()
|
private void RegisterPosix()
|
||||||
{
|
{
|
||||||
const int stdErrFileno = 2;
|
const int StdErrFileno = 2;
|
||||||
|
|
||||||
(int readFd, int writeFd) = MakePipe();
|
(int readFd, int writeFd) = MakePipe();
|
||||||
dup2(writeFd, stdErrFileno);
|
dup2(writeFd, StdErrFileno);
|
||||||
|
|
||||||
_pipeReader = CreateFileDescriptorStream(readFd);
|
_pipeReader = CreateFileDescriptorStream(readFd);
|
||||||
_pipeWriter = CreateFileDescriptorStream(writeFd);
|
_pipeWriter = CreateFileDescriptorStream(writeFd);
|
||||||
|
|
|
@ -6,8 +6,8 @@ using Ryujinx.Memory.Range;
|
||||||
using Ryujinx.Memory.Tracking;
|
using Ryujinx.Memory.Tracking;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Runtime.InteropServices;
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
|
|
||||||
namespace Ryujinx.Graphics.Gpu.Memory
|
namespace Ryujinx.Graphics.Gpu.Memory
|
||||||
|
|
|
@ -4,8 +4,8 @@ using Silk.NET.Vulkan;
|
||||||
using System;
|
using System;
|
||||||
using System.Runtime.CompilerServices;
|
using System.Runtime.CompilerServices;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using VkFormat = Silk.NET.Vulkan.Format;
|
|
||||||
using VkBuffer = Silk.NET.Vulkan.Buffer;
|
using VkBuffer = Silk.NET.Vulkan.Buffer;
|
||||||
|
using VkFormat = Silk.NET.Vulkan.Format;
|
||||||
|
|
||||||
namespace Ryujinx.Graphics.Vulkan
|
namespace Ryujinx.Graphics.Vulkan
|
||||||
{
|
{
|
||||||
|
|
|
@ -354,8 +354,8 @@ namespace Ryujinx.HLE.FileSystem
|
||||||
if (info.SpaceId != SaveDataSpaceId.User && info.SpaceId != SaveDataSpaceId.System)
|
if (info.SpaceId != SaveDataSpaceId.User && info.SpaceId != SaveDataSpaceId.System)
|
||||||
return Result.Success;
|
return Result.Success;
|
||||||
|
|
||||||
const string mountName = "SaveDir";
|
const string MountName = "SaveDir";
|
||||||
var mountNameU8 = mountName.ToU8Span();
|
var mountNameU8 = MountName.ToU8Span();
|
||||||
|
|
||||||
BisPartitionId partitionId = info.SpaceId switch
|
BisPartitionId partitionId = info.SpaceId switch
|
||||||
{
|
{
|
||||||
|
@ -368,7 +368,7 @@ namespace Ryujinx.HLE.FileSystem
|
||||||
if (rc.IsFailure()) return rc;
|
if (rc.IsFailure()) return rc;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var path = $"{mountName}:/save/{info.SaveDataId:x16}".ToU8Span();
|
var path = $"{MountName}:/save/{info.SaveDataId:x16}".ToU8Span();
|
||||||
|
|
||||||
rc = hos.Fs.GetEntryType(out _, path);
|
rc = hos.Fs.GetEntryType(out _, path);
|
||||||
|
|
||||||
|
@ -612,4 +612,4 @@ namespace Ryujinx.HLE.FileSystem
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -332,13 +332,13 @@ namespace Ryujinx.HLE.HOS
|
||||||
|
|
||||||
foreach (var service in services)
|
foreach (var service in services)
|
||||||
{
|
{
|
||||||
const ProcessCreationFlags flags =
|
const ProcessCreationFlags Flags =
|
||||||
ProcessCreationFlags.EnableAslr |
|
ProcessCreationFlags.EnableAslr |
|
||||||
ProcessCreationFlags.AddressSpace64Bit |
|
ProcessCreationFlags.AddressSpace64Bit |
|
||||||
ProcessCreationFlags.Is64Bit |
|
ProcessCreationFlags.Is64Bit |
|
||||||
ProcessCreationFlags.PoolPartitionSystem;
|
ProcessCreationFlags.PoolPartitionSystem;
|
||||||
|
|
||||||
ProcessCreationInfo creationInfo = new ProcessCreationInfo("Service", 1, 0, 0x8000000, 1, flags, 0, 0);
|
ProcessCreationInfo creationInfo = new ProcessCreationInfo("Service", 1, 0, 0x8000000, 1, Flags, 0, 0);
|
||||||
|
|
||||||
uint[] defaultCapabilities = new uint[]
|
uint[] defaultCapabilities = new uint[]
|
||||||
{
|
{
|
||||||
|
@ -554,4 +554,4 @@ namespace Ryujinx.HLE.HOS
|
||||||
IsPaused = pause;
|
IsPaused = pause;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,18 +83,18 @@ namespace Ryujinx.HLE.HOS.Services.Hid
|
||||||
|
|
||||||
public ControllerKeys UpdateStickButtons(JoystickPosition leftStick, JoystickPosition rightStick)
|
public ControllerKeys UpdateStickButtons(JoystickPosition leftStick, JoystickPosition rightStick)
|
||||||
{
|
{
|
||||||
const int stickButtonThreshold = short.MaxValue / 2;
|
const int StickButtonThreshold = short.MaxValue / 2;
|
||||||
ControllerKeys result = 0;
|
ControllerKeys result = 0;
|
||||||
|
|
||||||
result |= (leftStick.Dx < -stickButtonThreshold) ? ControllerKeys.LStickLeft : result;
|
result |= (leftStick.Dx < -StickButtonThreshold) ? ControllerKeys.LStickLeft : result;
|
||||||
result |= (leftStick.Dx > stickButtonThreshold) ? ControllerKeys.LStickRight : result;
|
result |= (leftStick.Dx > StickButtonThreshold) ? ControllerKeys.LStickRight : result;
|
||||||
result |= (leftStick.Dy < -stickButtonThreshold) ? ControllerKeys.LStickDown : result;
|
result |= (leftStick.Dy < -StickButtonThreshold) ? ControllerKeys.LStickDown : result;
|
||||||
result |= (leftStick.Dy > stickButtonThreshold) ? ControllerKeys.LStickUp : result;
|
result |= (leftStick.Dy > StickButtonThreshold) ? ControllerKeys.LStickUp : result;
|
||||||
|
|
||||||
result |= (rightStick.Dx < -stickButtonThreshold) ? ControllerKeys.RStickLeft : result;
|
result |= (rightStick.Dx < -StickButtonThreshold) ? ControllerKeys.RStickLeft : result;
|
||||||
result |= (rightStick.Dx > stickButtonThreshold) ? ControllerKeys.RStickRight : result;
|
result |= (rightStick.Dx > StickButtonThreshold) ? ControllerKeys.RStickRight : result;
|
||||||
result |= (rightStick.Dy < -stickButtonThreshold) ? ControllerKeys.RStickDown : result;
|
result |= (rightStick.Dy < -StickButtonThreshold) ? ControllerKeys.RStickDown : result;
|
||||||
result |= (rightStick.Dy > stickButtonThreshold) ? ControllerKeys.RStickUp : result;
|
result |= (rightStick.Dy > StickButtonThreshold) ? ControllerKeys.RStickUp : result;
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,7 @@ namespace Ryujinx.HLE.HOS.Services.Mii
|
||||||
{
|
{
|
||||||
public static ushort CalculateCrc16(ReadOnlySpan<byte> data, int crc, bool reverseEndianess)
|
public static ushort CalculateCrc16(ReadOnlySpan<byte> data, int crc, bool reverseEndianess)
|
||||||
{
|
{
|
||||||
const ushort poly = 0x1021;
|
const ushort Poly = 0x1021;
|
||||||
|
|
||||||
for (int i = 0; i < data.Length; i++)
|
for (int i = 0; i < data.Length; i++)
|
||||||
{
|
{
|
||||||
|
@ -20,7 +20,7 @@ namespace Ryujinx.HLE.HOS.Services.Mii
|
||||||
|
|
||||||
if ((crc & 0x10000) != 0)
|
if ((crc & 0x10000) != 0)
|
||||||
{
|
{
|
||||||
crc = (crc ^ poly) & 0xFFFF;
|
crc = (crc ^ Poly) & 0xFFFF;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -134,9 +134,9 @@ namespace Ryujinx.HLE.HOS.Services.Sdb.Pl
|
||||||
|
|
||||||
private void WriteMagicAndSize(ulong offset, int size)
|
private void WriteMagicAndSize(ulong offset, int size)
|
||||||
{
|
{
|
||||||
const int key = 0x49621806;
|
const int Key = 0x49621806;
|
||||||
|
|
||||||
int encryptedSize = BinaryPrimitives.ReverseEndianness(size ^ key);
|
int encryptedSize = BinaryPrimitives.ReverseEndianness(size ^ Key);
|
||||||
|
|
||||||
_storage.GetRef<int>(offset + 0) = (int)BFTTFMagic;
|
_storage.GetRef<int>(offset + 0) = (int)BFTTFMagic;
|
||||||
_storage.GetRef<int>(offset + 4) = encryptedSize;
|
_storage.GetRef<int>(offset + 4) = encryptedSize;
|
||||||
|
@ -180,4 +180,4 @@ namespace Ryujinx.HLE.HOS.Services.Sdb.Pl
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,13 +70,13 @@ namespace Ryujinx.HLE.HOS.Services
|
||||||
Name = name;
|
Name = name;
|
||||||
SmObjectFactory = smObjectFactory;
|
SmObjectFactory = smObjectFactory;
|
||||||
|
|
||||||
const ProcessCreationFlags flags =
|
const ProcessCreationFlags Flags =
|
||||||
ProcessCreationFlags.EnableAslr |
|
ProcessCreationFlags.EnableAslr |
|
||||||
ProcessCreationFlags.AddressSpace64Bit |
|
ProcessCreationFlags.AddressSpace64Bit |
|
||||||
ProcessCreationFlags.Is64Bit |
|
ProcessCreationFlags.Is64Bit |
|
||||||
ProcessCreationFlags.PoolPartitionSystem;
|
ProcessCreationFlags.PoolPartitionSystem;
|
||||||
|
|
||||||
ProcessCreationInfo creationInfo = new ProcessCreationInfo("Service", 1, 0, 0x8000000, 1, flags, 0, 0);
|
ProcessCreationInfo creationInfo = new ProcessCreationInfo("Service", 1, 0, 0x8000000, 1, Flags, 0, 0);
|
||||||
|
|
||||||
KernelStatic.StartInitialProcess(context, creationInfo, DefaultCapabilities, 44, Main);
|
KernelStatic.StartInitialProcess(context, creationInfo, DefaultCapabilities, 44, Main);
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,43 +43,43 @@ namespace Ryujinx.HLE.HOS.Services.Settings
|
||||||
return ResultCode.Success;
|
return ResultCode.Success;
|
||||||
}
|
}
|
||||||
|
|
||||||
const byte majorFwVersion = 0x03;
|
const byte MajorFwVersion = 0x03;
|
||||||
const byte minorFwVersion = 0x00;
|
const byte MinorFwVersion = 0x00;
|
||||||
const byte microFwVersion = 0x00;
|
const byte MicroFwVersion = 0x00;
|
||||||
const byte unknown = 0x00; //Build?
|
const byte Unknown = 0x00; //Build?
|
||||||
|
|
||||||
const int revisionNumber = 0x0A;
|
const int RevisionNumber = 0x0A;
|
||||||
|
|
||||||
const string platform = "NX";
|
const string Platform = "NX";
|
||||||
const string unknownHex = "7fbde2b0bba4d14107bf836e4643043d9f6c8e47";
|
const string UnknownHex = "7fbde2b0bba4d14107bf836e4643043d9f6c8e47";
|
||||||
const string version = "3.0.0";
|
const string Version = "3.0.0";
|
||||||
const string build = "NintendoSDK Firmware for NX 3.0.0-10.0";
|
const string Build = "NintendoSDK Firmware for NX 3.0.0-10.0";
|
||||||
|
|
||||||
// http://switchbrew.org/index.php?title=System_Version_Title
|
// http://switchbrew.org/index.php?title=System_Version_Title
|
||||||
using (MemoryStream ms = new MemoryStream(0x100))
|
using (MemoryStream ms = new MemoryStream(0x100))
|
||||||
{
|
{
|
||||||
BinaryWriter writer = new BinaryWriter(ms);
|
BinaryWriter writer = new BinaryWriter(ms);
|
||||||
|
|
||||||
writer.Write(majorFwVersion);
|
writer.Write(MajorFwVersion);
|
||||||
writer.Write(minorFwVersion);
|
writer.Write(MinorFwVersion);
|
||||||
writer.Write(microFwVersion);
|
writer.Write(MicroFwVersion);
|
||||||
writer.Write(unknown);
|
writer.Write(Unknown);
|
||||||
|
|
||||||
writer.Write(revisionNumber);
|
writer.Write(RevisionNumber);
|
||||||
|
|
||||||
writer.Write(Encoding.ASCII.GetBytes(platform));
|
writer.Write(Encoding.ASCII.GetBytes(Platform));
|
||||||
|
|
||||||
ms.Seek(0x28, SeekOrigin.Begin);
|
ms.Seek(0x28, SeekOrigin.Begin);
|
||||||
|
|
||||||
writer.Write(Encoding.ASCII.GetBytes(unknownHex));
|
writer.Write(Encoding.ASCII.GetBytes(UnknownHex));
|
||||||
|
|
||||||
ms.Seek(0x68, SeekOrigin.Begin);
|
ms.Seek(0x68, SeekOrigin.Begin);
|
||||||
|
|
||||||
writer.Write(Encoding.ASCII.GetBytes(version));
|
writer.Write(Encoding.ASCII.GetBytes(Version));
|
||||||
|
|
||||||
ms.Seek(0x80, SeekOrigin.Begin);
|
ms.Seek(0x80, SeekOrigin.Begin);
|
||||||
|
|
||||||
writer.Write(Encoding.ASCII.GetBytes(build));
|
writer.Write(Encoding.ASCII.GetBytes(Build));
|
||||||
|
|
||||||
context.Memory.Write(replyPos, ms.ToArray());
|
context.Memory.Write(replyPos, ms.ToArray());
|
||||||
}
|
}
|
||||||
|
|
|
@ -354,16 +354,16 @@ namespace Ryujinx.HLE.HOS.Services.Vi.RootService
|
||||||
|
|
||||||
private ulong GetA8B8G8R8LayerSize(int width, int height, out int pitch, out int alignment)
|
private ulong GetA8B8G8R8LayerSize(int width, int height, out int pitch, out int alignment)
|
||||||
{
|
{
|
||||||
const int defaultAlignment = 0x1000;
|
const int DefaultAlignment = 0x1000;
|
||||||
const ulong defaultSize = 0x20000;
|
const ulong DefaultSize = 0x20000;
|
||||||
|
|
||||||
alignment = defaultAlignment;
|
alignment = DefaultAlignment;
|
||||||
pitch = BitUtils.AlignUp(BitUtils.DivRoundUp(width * 32, 8), 64);
|
pitch = BitUtils.AlignUp(BitUtils.DivRoundUp(width * 32, 8), 64);
|
||||||
|
|
||||||
int memorySize = pitch * BitUtils.AlignUp(height, 64);
|
int memorySize = pitch * BitUtils.AlignUp(height, 64);
|
||||||
ulong requiredMemorySize = (ulong)BitUtils.AlignUp(memorySize, alignment);
|
ulong requiredMemorySize = (ulong)BitUtils.AlignUp(memorySize, alignment);
|
||||||
|
|
||||||
return (requiredMemorySize + defaultSize - 1) / defaultSize * defaultSize;
|
return (requiredMemorySize + DefaultSize - 1) / DefaultSize * DefaultSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
[CommandCmif(2450)]
|
[CommandCmif(2450)]
|
||||||
|
@ -484,4 +484,4 @@ namespace Ryujinx.HLE.HOS.Services.Vi.RootService
|
||||||
return ResultCode.Success;
|
return ResultCode.Success;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -96,14 +96,14 @@ namespace Ryujinx.HLE.HOS.Tamper
|
||||||
|
|
||||||
public static byte[] ParseRawInstruction(string rawInstruction)
|
public static byte[] ParseRawInstruction(string rawInstruction)
|
||||||
{
|
{
|
||||||
const int wordSize = 2 * sizeof(uint);
|
const int WordSize = 2 * sizeof(uint);
|
||||||
|
|
||||||
// Instructions are multi-word, with 32bit words. Split the raw instruction
|
// Instructions are multi-word, with 32bit words. Split the raw instruction
|
||||||
// and parse each word into individual nybbles of bits.
|
// and parse each word into individual nybbles of bits.
|
||||||
|
|
||||||
var words = rawInstruction.Split((char[])null, StringSplitOptions.RemoveEmptyEntries);
|
var words = rawInstruction.Split((char[])null, StringSplitOptions.RemoveEmptyEntries);
|
||||||
|
|
||||||
byte[] instruction = new byte[wordSize * words.Length];
|
byte[] instruction = new byte[WordSize * words.Length];
|
||||||
|
|
||||||
if (words.Length == 0)
|
if (words.Length == 0)
|
||||||
{
|
{
|
||||||
|
@ -114,14 +114,14 @@ namespace Ryujinx.HLE.HOS.Tamper
|
||||||
{
|
{
|
||||||
string word = words[wordIndex];
|
string word = words[wordIndex];
|
||||||
|
|
||||||
if (word.Length != wordSize)
|
if (word.Length != WordSize)
|
||||||
{
|
{
|
||||||
throw new TamperCompilationException($"Invalid word length for {word} in Atmosphere cheat");
|
throw new TamperCompilationException($"Invalid word length for {word} in Atmosphere cheat");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int nybbleIndex = 0; nybbleIndex < wordSize; nybbleIndex++)
|
for (int nybbleIndex = 0; nybbleIndex < WordSize; nybbleIndex++)
|
||||||
{
|
{
|
||||||
int index = wordIndex * wordSize + nybbleIndex;
|
int index = wordIndex * WordSize + nybbleIndex;
|
||||||
|
|
||||||
instruction[index] = byte.Parse(word.AsSpan(nybbleIndex, 1), NumberStyles.HexNumber, CultureInfo.InvariantCulture);
|
instruction[index] = byte.Parse(word.AsSpan(nybbleIndex, 1), NumberStyles.HexNumber, CultureInfo.InvariantCulture);
|
||||||
}
|
}
|
||||||
|
|
|
@ -100,14 +100,14 @@ namespace Ryujinx.Tests.Memory
|
||||||
[Test]
|
[Test]
|
||||||
public void DirtyRegionOrdering([Values] bool smart)
|
public void DirtyRegionOrdering([Values] bool smart)
|
||||||
{
|
{
|
||||||
const int pageCount = 32;
|
const int PageCount = 32;
|
||||||
IMultiRegionHandle handle = GetGranular(smart, 0, PageSize * pageCount, PageSize);
|
IMultiRegionHandle handle = GetGranular(smart, 0, PageSize * PageCount, PageSize);
|
||||||
|
|
||||||
Random random = new();
|
Random random = new();
|
||||||
|
|
||||||
PreparePages(handle, pageCount);
|
PreparePages(handle, PageCount);
|
||||||
|
|
||||||
IEnumerable<int> halfRange = Enumerable.Range(0, pageCount / 2);
|
IEnumerable<int> halfRange = Enumerable.Range(0, PageCount / 2);
|
||||||
List<int> odd = halfRange.Select(x => x * 2 + 1).ToList();
|
List<int> odd = halfRange.Select(x => x * 2 + 1).ToList();
|
||||||
List<int> even = halfRange.Select(x => x * 2).ToList();
|
List<int> even = halfRange.Select(x => x * 2).ToList();
|
||||||
|
|
||||||
|
@ -117,9 +117,9 @@ namespace Ryujinx.Tests.Memory
|
||||||
_tracking.VirtualMemoryEvent((ulong)i * PageSize, PageSize, true);
|
_tracking.VirtualMemoryEvent((ulong)i * PageSize, PageSize, true);
|
||||||
});
|
});
|
||||||
|
|
||||||
int oddRegionCount = ExpectQueryInOrder(handle, 0, PageSize * pageCount, (address) => (address / PageSize) % 2 == 1);
|
int oddRegionCount = ExpectQueryInOrder(handle, 0, PageSize * PageCount, (address) => (address / PageSize) % 2 == 1);
|
||||||
|
|
||||||
Assert.AreEqual(oddRegionCount, pageCount / 2); // Must have written to all odd pages.
|
Assert.AreEqual(oddRegionCount, PageCount / 2); // Must have written to all odd pages.
|
||||||
|
|
||||||
// Write to all the even pages.
|
// Write to all the even pages.
|
||||||
RandomOrder(random, even, (i) =>
|
RandomOrder(random, even, (i) =>
|
||||||
|
@ -127,9 +127,9 @@ namespace Ryujinx.Tests.Memory
|
||||||
_tracking.VirtualMemoryEvent((ulong)i * PageSize, PageSize, true);
|
_tracking.VirtualMemoryEvent((ulong)i * PageSize, PageSize, true);
|
||||||
});
|
});
|
||||||
|
|
||||||
int evenRegionCount = ExpectQueryInOrder(handle, 0, PageSize * pageCount, (address) => (address / PageSize) % 2 == 0);
|
int evenRegionCount = ExpectQueryInOrder(handle, 0, PageSize * PageCount, (address) => (address / PageSize) % 2 == 0);
|
||||||
|
|
||||||
Assert.AreEqual(evenRegionCount, pageCount / 2);
|
Assert.AreEqual(evenRegionCount, PageCount / 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
|
@ -142,14 +142,14 @@ namespace Ryujinx.Tests.Memory
|
||||||
// This is useful for situations where we know that the data was complete when the sequence number was set.
|
// This is useful for situations where we know that the data was complete when the sequence number was set.
|
||||||
// ...essentially, when that data can only be updated on a future sequence number.
|
// ...essentially, when that data can only be updated on a future sequence number.
|
||||||
|
|
||||||
const int pageCount = 32;
|
const int PageCount = 32;
|
||||||
IMultiRegionHandle handle = GetGranular(smart, 0, PageSize * pageCount, PageSize);
|
IMultiRegionHandle handle = GetGranular(smart, 0, PageSize * PageCount, PageSize);
|
||||||
|
|
||||||
PreparePages(handle, pageCount);
|
PreparePages(handle, PageCount);
|
||||||
|
|
||||||
Random random = new();
|
Random random = new();
|
||||||
|
|
||||||
IEnumerable<int> halfRange = Enumerable.Range(0, pageCount / 2);
|
IEnumerable<int> halfRange = Enumerable.Range(0, PageCount / 2);
|
||||||
List<int> odd = halfRange.Select(x => x * 2 + 1).ToList();
|
List<int> odd = halfRange.Select(x => x * 2 + 1).ToList();
|
||||||
List<int> even = halfRange.Select(x => x * 2).ToList();
|
List<int> even = halfRange.Select(x => x * 2).ToList();
|
||||||
|
|
||||||
|
@ -172,29 +172,29 @@ namespace Ryujinx.Tests.Memory
|
||||||
}, 1);
|
}, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert.AreEqual(oddRegionCount, pageCount / 2); // Must have written to all odd pages.
|
Assert.AreEqual(oddRegionCount, PageCount / 2); // Must have written to all odd pages.
|
||||||
|
|
||||||
// Write to all pages.
|
// Write to all pages.
|
||||||
|
|
||||||
_tracking.VirtualMemoryEvent(0, PageSize * pageCount, true);
|
_tracking.VirtualMemoryEvent(0, PageSize * PageCount, true);
|
||||||
|
|
||||||
// Only the even regions should be reported for sequence number 1.
|
// Only the even regions should be reported for sequence number 1.
|
||||||
|
|
||||||
int evenRegionCount = ExpectQueryInOrder(handle, 0, PageSize * pageCount, (address) => (address / PageSize) % 2 == 0, 1);
|
int evenRegionCount = ExpectQueryInOrder(handle, 0, PageSize * PageCount, (address) => (address / PageSize) % 2 == 0, 1);
|
||||||
|
|
||||||
Assert.AreEqual(evenRegionCount, pageCount / 2); // Must have written to all even pages.
|
Assert.AreEqual(evenRegionCount, PageCount / 2); // Must have written to all even pages.
|
||||||
|
|
||||||
oddRegionCount = 0;
|
oddRegionCount = 0;
|
||||||
|
|
||||||
handle.QueryModified(0, PageSize * pageCount, (address, range) => { oddRegionCount++; }, 1);
|
handle.QueryModified(0, PageSize * PageCount, (address, range) => { oddRegionCount++; }, 1);
|
||||||
|
|
||||||
Assert.AreEqual(oddRegionCount, 0); // Sequence number has not changed, so found no dirty subregions.
|
Assert.AreEqual(oddRegionCount, 0); // Sequence number has not changed, so found no dirty subregions.
|
||||||
|
|
||||||
// With sequence number 2, all all pages should be reported as modified.
|
// With sequence number 2, all all pages should be reported as modified.
|
||||||
|
|
||||||
oddRegionCount = ExpectQueryInOrder(handle, 0, PageSize * pageCount, (address) => (address / PageSize) % 2 == 1, 2);
|
oddRegionCount = ExpectQueryInOrder(handle, 0, PageSize * PageCount, (address) => (address / PageSize) % 2 == 1, 2);
|
||||||
|
|
||||||
Assert.AreEqual(oddRegionCount, pageCount / 2); // Must have written to all odd pages.
|
Assert.AreEqual(oddRegionCount, PageCount / 2); // Must have written to all odd pages.
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
|
@ -203,8 +203,8 @@ namespace Ryujinx.Tests.Memory
|
||||||
// Smart multi region handles dynamically change their tracking granularity based on QueryMemory calls.
|
// Smart multi region handles dynamically change their tracking granularity based on QueryMemory calls.
|
||||||
// This can save on reprotects on larger resources.
|
// This can save on reprotects on larger resources.
|
||||||
|
|
||||||
const int pageCount = 32;
|
const int PageCount = 32;
|
||||||
IMultiRegionHandle handle = GetGranular(true, 0, PageSize * pageCount, PageSize);
|
IMultiRegionHandle handle = GetGranular(true, 0, PageSize * PageCount, PageSize);
|
||||||
|
|
||||||
// Query some large regions to prep the subdivision of the tracking region.
|
// Query some large regions to prep the subdivision of the tracking region.
|
||||||
|
|
||||||
|
@ -253,27 +253,27 @@ namespace Ryujinx.Tests.Memory
|
||||||
public void DisposeMultiHandles([Values] bool smart)
|
public void DisposeMultiHandles([Values] bool smart)
|
||||||
{
|
{
|
||||||
// Create and initialize two overlapping Multi Region Handles, with PageSize granularity.
|
// Create and initialize two overlapping Multi Region Handles, with PageSize granularity.
|
||||||
const int pageCount = 32;
|
const int PageCount = 32;
|
||||||
const int overlapStart = 16;
|
const int OverlapStart = 16;
|
||||||
|
|
||||||
Assert.AreEqual(0, _tracking.GetRegionCount());
|
Assert.AreEqual(0, _tracking.GetRegionCount());
|
||||||
|
|
||||||
IMultiRegionHandle handleLow = GetGranular(smart, 0, PageSize * pageCount, PageSize);
|
IMultiRegionHandle handleLow = GetGranular(smart, 0, PageSize * PageCount, PageSize);
|
||||||
PreparePages(handleLow, pageCount);
|
PreparePages(handleLow, PageCount);
|
||||||
|
|
||||||
Assert.AreEqual(pageCount, _tracking.GetRegionCount());
|
Assert.AreEqual(PageCount, _tracking.GetRegionCount());
|
||||||
|
|
||||||
IMultiRegionHandle handleHigh = GetGranular(smart, PageSize * overlapStart, PageSize * pageCount, PageSize);
|
IMultiRegionHandle handleHigh = GetGranular(smart, PageSize * OverlapStart, PageSize * PageCount, PageSize);
|
||||||
PreparePages(handleHigh, pageCount, PageSize * overlapStart);
|
PreparePages(handleHigh, PageCount, PageSize * OverlapStart);
|
||||||
|
|
||||||
// Combined pages (and assuming overlapStart <= pageCount) should be pageCount after overlapStart.
|
// Combined pages (and assuming overlapStart <= pageCount) should be pageCount after overlapStart.
|
||||||
int totalPages = overlapStart + pageCount;
|
int totalPages = OverlapStart + PageCount;
|
||||||
|
|
||||||
Assert.AreEqual(totalPages, _tracking.GetRegionCount());
|
Assert.AreEqual(totalPages, _tracking.GetRegionCount());
|
||||||
|
|
||||||
handleLow.Dispose(); // After disposing one, the pages for the other remain.
|
handleLow.Dispose(); // After disposing one, the pages for the other remain.
|
||||||
|
|
||||||
Assert.AreEqual(pageCount, _tracking.GetRegionCount());
|
Assert.AreEqual(PageCount, _tracking.GetRegionCount());
|
||||||
|
|
||||||
handleHigh.Dispose(); // After disposing the other, there are no pages left.
|
handleHigh.Dispose(); // After disposing the other, there are no pages left.
|
||||||
|
|
||||||
|
|
|
@ -201,11 +201,11 @@ namespace Ryujinx.Tests.Memory
|
||||||
|
|
||||||
// This test should not throw or deadlock due to invalid state.
|
// This test should not throw or deadlock due to invalid state.
|
||||||
|
|
||||||
const int threadCount = 1;
|
const int ThreadCount = 1;
|
||||||
const int handlesPerThread = 16;
|
const int HandlesPerThread = 16;
|
||||||
long finishedTime = 0;
|
long finishedTime = 0;
|
||||||
|
|
||||||
RegionHandle[] handles = new RegionHandle[threadCount * handlesPerThread];
|
RegionHandle[] handles = new RegionHandle[ThreadCount * HandlesPerThread];
|
||||||
Random globalRand = new();
|
Random globalRand = new();
|
||||||
|
|
||||||
for (int i = 0; i < handles.Length; i++)
|
for (int i = 0; i < handles.Length; i++)
|
||||||
|
@ -218,16 +218,16 @@ namespace Ryujinx.Tests.Memory
|
||||||
|
|
||||||
// Dirty flag consumer threads
|
// Dirty flag consumer threads
|
||||||
int dirtyFlagReprotects = 0;
|
int dirtyFlagReprotects = 0;
|
||||||
for (int i = 0; i < threadCount; i++)
|
for (int i = 0; i < ThreadCount; i++)
|
||||||
{
|
{
|
||||||
int randSeed = i;
|
int randSeed = i;
|
||||||
testThreads.Add(new Thread(() =>
|
testThreads.Add(new Thread(() =>
|
||||||
{
|
{
|
||||||
int handleBase = randSeed * handlesPerThread;
|
int handleBase = randSeed * HandlesPerThread;
|
||||||
while (Stopwatch.GetTimestamp() < finishedTime)
|
while (Stopwatch.GetTimestamp() < finishedTime)
|
||||||
{
|
{
|
||||||
Random random = new(randSeed);
|
Random random = new(randSeed);
|
||||||
RegionHandle handle = handles[handleBase + random.Next(handlesPerThread)];
|
RegionHandle handle = handles[handleBase + random.Next(HandlesPerThread)];
|
||||||
|
|
||||||
if (handle.Dirty)
|
if (handle.Dirty)
|
||||||
{
|
{
|
||||||
|
@ -240,16 +240,16 @@ namespace Ryujinx.Tests.Memory
|
||||||
|
|
||||||
// Write trigger threads
|
// Write trigger threads
|
||||||
int writeTriggers = 0;
|
int writeTriggers = 0;
|
||||||
for (int i = 0; i < threadCount; i++)
|
for (int i = 0; i < ThreadCount; i++)
|
||||||
{
|
{
|
||||||
int randSeed = i;
|
int randSeed = i;
|
||||||
testThreads.Add(new Thread(() =>
|
testThreads.Add(new Thread(() =>
|
||||||
{
|
{
|
||||||
Random random = new(randSeed);
|
Random random = new(randSeed);
|
||||||
ulong handleBase = (ulong)(randSeed * handlesPerThread * PageSize);
|
ulong handleBase = (ulong)(randSeed * HandlesPerThread * PageSize);
|
||||||
while (Stopwatch.GetTimestamp() < finishedTime)
|
while (Stopwatch.GetTimestamp() < finishedTime)
|
||||||
{
|
{
|
||||||
_tracking.VirtualMemoryEvent(handleBase + (ulong)random.Next(PageSize * handlesPerThread), PageSize / 2, true);
|
_tracking.VirtualMemoryEvent(handleBase + (ulong)random.Next(PageSize * HandlesPerThread), PageSize / 2, true);
|
||||||
Interlocked.Increment(ref writeTriggers);
|
Interlocked.Increment(ref writeTriggers);
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
@ -257,12 +257,12 @@ namespace Ryujinx.Tests.Memory
|
||||||
|
|
||||||
// Handle create/delete threads
|
// Handle create/delete threads
|
||||||
int handleLifecycles = 0;
|
int handleLifecycles = 0;
|
||||||
for (int i = 0; i < threadCount; i++)
|
for (int i = 0; i < ThreadCount; i++)
|
||||||
{
|
{
|
||||||
int randSeed = i;
|
int randSeed = i;
|
||||||
testThreads.Add(new Thread(() =>
|
testThreads.Add(new Thread(() =>
|
||||||
{
|
{
|
||||||
int maxAddress = threadCount * handlesPerThread * PageSize;
|
int maxAddress = ThreadCount * HandlesPerThread * PageSize;
|
||||||
Random random = new(randSeed + 512);
|
Random random = new(randSeed + 512);
|
||||||
while (Stopwatch.GetTimestamp() < finishedTime)
|
while (Stopwatch.GetTimestamp() < finishedTime)
|
||||||
{
|
{
|
||||||
|
@ -315,17 +315,17 @@ namespace Ryujinx.Tests.Memory
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
const int threadCount = 16;
|
const int ThreadCount = 16;
|
||||||
const int iterationCount = 10000;
|
const int IterationCount = 10000;
|
||||||
Thread[] signalThreads = new Thread[threadCount];
|
Thread[] signalThreads = new Thread[ThreadCount];
|
||||||
|
|
||||||
for (int i = 0; i < threadCount; i++)
|
for (int i = 0; i < ThreadCount; i++)
|
||||||
{
|
{
|
||||||
int randSeed = i;
|
int randSeed = i;
|
||||||
signalThreads[i] = new Thread(() =>
|
signalThreads[i] = new Thread(() =>
|
||||||
{
|
{
|
||||||
Random random = new(randSeed);
|
Random random = new(randSeed);
|
||||||
for (int j = 0; j < iterationCount; j++)
|
for (int j = 0; j < IterationCount; j++)
|
||||||
{
|
{
|
||||||
_tracking.VirtualMemoryEvent((ulong)random.Next(PageSize), 4, false);
|
_tracking.VirtualMemoryEvent((ulong)random.Next(PageSize), 4, false);
|
||||||
}
|
}
|
||||||
|
@ -333,14 +333,14 @@ namespace Ryujinx.Tests.Memory
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < threadCount; i++)
|
for (int i = 0; i < ThreadCount; i++)
|
||||||
{
|
{
|
||||||
signalThreads[i].Start();
|
signalThreads[i].Start();
|
||||||
}
|
}
|
||||||
|
|
||||||
while (signalThreadsDone != -1)
|
while (signalThreadsDone != -1)
|
||||||
{
|
{
|
||||||
if (signalThreadsDone == threadCount)
|
if (signalThreadsDone == ThreadCount)
|
||||||
{
|
{
|
||||||
signalThreadsDone = -1;
|
signalThreadsDone = -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -359,7 +359,7 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Test]
|
[Test]
|
||||||
public void MiscR()
|
public void MiscR()
|
||||||
{
|
{
|
||||||
const ulong result = 5;
|
const ulong Result = 5;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
0x0000000000001000: MOV X0, #2
|
0x0000000000001000: MOV X0, #2
|
||||||
|
@ -374,7 +374,7 @@ namespace Ryujinx.Tests.Cpu
|
||||||
Opcode(0xD65F03C0);
|
Opcode(0xD65F03C0);
|
||||||
ExecuteOpcodes();
|
ExecuteOpcodes();
|
||||||
|
|
||||||
Assert.That(GetContext().GetX(0), Is.EqualTo(result));
|
Assert.That(GetContext().GetX(0), Is.EqualTo(Result));
|
||||||
|
|
||||||
Reset();
|
Reset();
|
||||||
|
|
||||||
|
@ -391,7 +391,7 @@ namespace Ryujinx.Tests.Cpu
|
||||||
Opcode(0xD65F03C0);
|
Opcode(0xD65F03C0);
|
||||||
ExecuteOpcodes();
|
ExecuteOpcodes();
|
||||||
|
|
||||||
Assert.That(GetContext().GetX(0), Is.EqualTo(result));
|
Assert.That(GetContext().GetX(0), Is.EqualTo(Result));
|
||||||
}
|
}
|
||||||
|
|
||||||
[Explicit]
|
[Explicit]
|
||||||
|
@ -479,4 +479,4 @@ namespace Ryujinx.Tests.Cpu
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -110,9 +110,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
public void Dup_S_B([ValueSource(nameof(_8B_))] ulong a,
|
public void Dup_S_B([ValueSource(nameof(_8B_))] ulong a,
|
||||||
[Values(0u, 15u)] uint index)
|
[Values(0u, 15u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 0;
|
const int TestSize = 0;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x5E000420; // RESERVED
|
uint opcode = 0x5E000420; // RESERVED
|
||||||
opcode |= (imm5 << 16);
|
opcode |= (imm5 << 16);
|
||||||
|
@ -130,9 +130,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
public void Dup_S_H([ValueSource(nameof(_4H_))] ulong a,
|
public void Dup_S_H([ValueSource(nameof(_4H_))] ulong a,
|
||||||
[Values(0u, 7u)] uint index)
|
[Values(0u, 7u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 1;
|
const int TestSize = 1;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x5E000420; // RESERVED
|
uint opcode = 0x5E000420; // RESERVED
|
||||||
opcode |= (imm5 << 16);
|
opcode |= (imm5 << 16);
|
||||||
|
@ -150,9 +150,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
public void Dup_S_S([ValueSource(nameof(_2S_))] ulong a,
|
public void Dup_S_S([ValueSource(nameof(_2S_))] ulong a,
|
||||||
[Values(0u, 1u, 2u, 3u)] uint index)
|
[Values(0u, 1u, 2u, 3u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 2;
|
const int TestSize = 2;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x5E000420; // RESERVED
|
uint opcode = 0x5E000420; // RESERVED
|
||||||
opcode |= (imm5 << 16);
|
opcode |= (imm5 << 16);
|
||||||
|
@ -170,9 +170,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
public void Dup_S_D([ValueSource(nameof(_1D_))] ulong a,
|
public void Dup_S_D([ValueSource(nameof(_1D_))] ulong a,
|
||||||
[Values(0u, 1u)] uint index)
|
[Values(0u, 1u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 3;
|
const int TestSize = 3;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x5E000420; // RESERVED
|
uint opcode = 0x5E000420; // RESERVED
|
||||||
opcode |= (imm5 << 16);
|
opcode |= (imm5 << 16);
|
||||||
|
@ -194,9 +194,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Values(0u, 15u)] uint index,
|
[Values(0u, 15u)] uint index,
|
||||||
[Values(0b0u, 0b1u)] uint q) // <8B, 16B>
|
[Values(0b0u, 0b1u)] uint q) // <8B, 16B>
|
||||||
{
|
{
|
||||||
const int size = 0;
|
const int TestSize = 0;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E000400; // RESERVED
|
uint opcode = 0x0E000400; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -219,9 +219,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Values(0u, 7u)] uint index,
|
[Values(0u, 7u)] uint index,
|
||||||
[Values(0b0u, 0b1u)] uint q) // <4H, 8H>
|
[Values(0b0u, 0b1u)] uint q) // <4H, 8H>
|
||||||
{
|
{
|
||||||
const int size = 1;
|
const int TestSize = 1;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E000400; // RESERVED
|
uint opcode = 0x0E000400; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -244,9 +244,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Values(0u, 1u, 2u, 3u)] uint index,
|
[Values(0u, 1u, 2u, 3u)] uint index,
|
||||||
[Values(0b0u, 0b1u)] uint q) // <2S, 4S>
|
[Values(0b0u, 0b1u)] uint q) // <2S, 4S>
|
||||||
{
|
{
|
||||||
const int size = 2;
|
const int TestSize = 2;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E000400; // RESERVED
|
uint opcode = 0x0E000400; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -269,9 +269,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Values(0u, 1u)] uint index,
|
[Values(0u, 1u)] uint index,
|
||||||
[Values(0b1u)] uint q) // <2D>
|
[Values(0b1u)] uint q) // <2D>
|
||||||
{
|
{
|
||||||
const int size = 3;
|
const int TestSize = 3;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E000400; // RESERVED
|
uint opcode = 0x0E000400; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -293,9 +293,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_W_))] uint wn,
|
[ValueSource(nameof(_W_))] uint wn,
|
||||||
[Values(0u, 15u)] uint index)
|
[Values(0u, 15u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 0;
|
const int TestSize = 0;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x4E001C00; // RESERVED
|
uint opcode = 0x4E001C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -316,9 +316,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_W_))] uint wn,
|
[ValueSource(nameof(_W_))] uint wn,
|
||||||
[Values(0u, 7u)] uint index)
|
[Values(0u, 7u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 1;
|
const int TestSize = 1;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x4E001C00; // RESERVED
|
uint opcode = 0x4E001C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -339,9 +339,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_W_))] uint wn,
|
[ValueSource(nameof(_W_))] uint wn,
|
||||||
[Values(0u, 1u, 2u, 3u)] uint index)
|
[Values(0u, 1u, 2u, 3u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 2;
|
const int TestSize = 2;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x4E001C00; // RESERVED
|
uint opcode = 0x4E001C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -362,9 +362,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_X_))] ulong xn,
|
[ValueSource(nameof(_X_))] ulong xn,
|
||||||
[Values(0u, 1u)] uint index)
|
[Values(0u, 1u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 3;
|
const int TestSize = 3;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x4E001C00; // RESERVED
|
uint opcode = 0x4E001C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -386,10 +386,10 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Values(0u, 15u)] uint dstIndex,
|
[Values(0u, 15u)] uint dstIndex,
|
||||||
[Values(0u, 15u)] uint srcIndex)
|
[Values(0u, 15u)] uint srcIndex)
|
||||||
{
|
{
|
||||||
const int size = 0;
|
const int TestSize = 0;
|
||||||
|
|
||||||
uint imm5 = (dstIndex << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (dstIndex << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
uint imm4 = (srcIndex << size) & 0xFu;
|
uint imm4 = (srcIndex << TestSize) & 0xFu;
|
||||||
|
|
||||||
uint opcode = 0x6E000400; // RESERVED
|
uint opcode = 0x6E000400; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -412,10 +412,10 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Values(0u, 7u)] uint dstIndex,
|
[Values(0u, 7u)] uint dstIndex,
|
||||||
[Values(0u, 7u)] uint srcIndex)
|
[Values(0u, 7u)] uint srcIndex)
|
||||||
{
|
{
|
||||||
const int size = 1;
|
const int TestSize = 1;
|
||||||
|
|
||||||
uint imm5 = (dstIndex << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (dstIndex << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
uint imm4 = (srcIndex << size) & 0xFu;
|
uint imm4 = (srcIndex << TestSize) & 0xFu;
|
||||||
|
|
||||||
uint opcode = 0x6E000400; // RESERVED
|
uint opcode = 0x6E000400; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -438,10 +438,10 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Values(0u, 1u, 2u, 3u)] uint dstIndex,
|
[Values(0u, 1u, 2u, 3u)] uint dstIndex,
|
||||||
[Values(0u, 1u, 2u, 3u)] uint srcIndex)
|
[Values(0u, 1u, 2u, 3u)] uint srcIndex)
|
||||||
{
|
{
|
||||||
const int size = 2;
|
const int TestSize = 2;
|
||||||
|
|
||||||
uint imm5 = (dstIndex << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (dstIndex << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
uint imm4 = (srcIndex << size) & 0xFu;
|
uint imm4 = (srcIndex << TestSize) & 0xFu;
|
||||||
|
|
||||||
uint opcode = 0x6E000400; // RESERVED
|
uint opcode = 0x6E000400; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -464,10 +464,10 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[Values(0u, 1u)] uint dstIndex,
|
[Values(0u, 1u)] uint dstIndex,
|
||||||
[Values(0u, 1u)] uint srcIndex)
|
[Values(0u, 1u)] uint srcIndex)
|
||||||
{
|
{
|
||||||
const int size = 3;
|
const int TestSize = 3;
|
||||||
|
|
||||||
uint imm5 = (dstIndex << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (dstIndex << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
uint imm4 = (srcIndex << size) & 0xFu;
|
uint imm4 = (srcIndex << TestSize) & 0xFu;
|
||||||
|
|
||||||
uint opcode = 0x6E000400; // RESERVED
|
uint opcode = 0x6E000400; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -488,9 +488,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_8B_))] ulong a,
|
[ValueSource(nameof(_8B_))] ulong a,
|
||||||
[Values(0u, 15u)] uint index)
|
[Values(0u, 15u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 0;
|
const int TestSize = 0;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E002C00; // RESERVED
|
uint opcode = 0x0E002C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -511,9 +511,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_4H_))] ulong a,
|
[ValueSource(nameof(_4H_))] ulong a,
|
||||||
[Values(0u, 7u)] uint index)
|
[Values(0u, 7u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 1;
|
const int TestSize = 1;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E002C00; // RESERVED
|
uint opcode = 0x0E002C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -534,9 +534,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_8B_))] ulong a,
|
[ValueSource(nameof(_8B_))] ulong a,
|
||||||
[Values(0u, 15u)] uint index)
|
[Values(0u, 15u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 0;
|
const int TestSize = 0;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x4E002C00; // RESERVED
|
uint opcode = 0x4E002C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -556,9 +556,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_4H_))] ulong a,
|
[ValueSource(nameof(_4H_))] ulong a,
|
||||||
[Values(0u, 7u)] uint index)
|
[Values(0u, 7u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 1;
|
const int TestSize = 1;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x4E002C00; // RESERVED
|
uint opcode = 0x4E002C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -578,9 +578,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_2S_))] ulong a,
|
[ValueSource(nameof(_2S_))] ulong a,
|
||||||
[Values(0u, 1u, 2u, 3u)] uint index)
|
[Values(0u, 1u, 2u, 3u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 2;
|
const int TestSize = 2;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x4E002C00; // RESERVED
|
uint opcode = 0x4E002C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -600,9 +600,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_8B_))] ulong a,
|
[ValueSource(nameof(_8B_))] ulong a,
|
||||||
[Values(0u, 15u)] uint index)
|
[Values(0u, 15u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 0;
|
const int TestSize = 0;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E003C00; // RESERVED
|
uint opcode = 0x0E003C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -623,9 +623,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_4H_))] ulong a,
|
[ValueSource(nameof(_4H_))] ulong a,
|
||||||
[Values(0u, 7u)] uint index)
|
[Values(0u, 7u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 1;
|
const int TestSize = 1;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E003C00; // RESERVED
|
uint opcode = 0x0E003C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -646,9 +646,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_2S_))] ulong a,
|
[ValueSource(nameof(_2S_))] ulong a,
|
||||||
[Values(0u, 1u, 2u, 3u)] uint index)
|
[Values(0u, 1u, 2u, 3u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 2;
|
const int TestSize = 2;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x0E003C00; // RESERVED
|
uint opcode = 0x0E003C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -669,9 +669,9 @@ namespace Ryujinx.Tests.Cpu
|
||||||
[ValueSource(nameof(_1D_))] ulong a,
|
[ValueSource(nameof(_1D_))] ulong a,
|
||||||
[Values(0u, 1u)] uint index)
|
[Values(0u, 1u)] uint index)
|
||||||
{
|
{
|
||||||
const int size = 3;
|
const int TestSize = 3;
|
||||||
|
|
||||||
uint imm5 = (index << (size + 1) | 1u << size) & 0x1Fu;
|
uint imm5 = (index << (TestSize + 1) | 1u << TestSize) & 0x1Fu;
|
||||||
|
|
||||||
uint opcode = 0x4E003C00; // RESERVED
|
uint opcode = 0x4E003C00; // RESERVED
|
||||||
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
|
||||||
|
@ -686,4 +686,4 @@ namespace Ryujinx.Tests.Cpu
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
#define SimdMemory32
|
#define SimdMemory32
|
||||||
|
|
||||||
using ARMeilleure.State;
|
using ARMeilleure.State;
|
||||||
using Ryujinx.Memory;
|
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
|
using Ryujinx.Memory;
|
||||||
using System;
|
using System;
|
||||||
|
|
||||||
namespace Ryujinx.Tests.Cpu
|
namespace Ryujinx.Tests.Cpu
|
||||||
|
|
|
@ -14,17 +14,17 @@ namespace Ryujinx.Tests.Cpu
|
||||||
#region "Helper methods"
|
#region "Helper methods"
|
||||||
private static ulong GenIdxsForTbls(int regs)
|
private static ulong GenIdxsForTbls(int regs)
|
||||||
{
|
{
|
||||||
const byte idxInRngMin = 0;
|
const byte IdxInRngMin = 0;
|
||||||
byte idxInRngMax = (byte)((16 * regs) - 1);
|
byte idxInRngMax = (byte)((16 * regs) - 1);
|
||||||
byte idxOutRngMin = (byte) (16 * regs);
|
byte idxOutRngMin = (byte) (16 * regs);
|
||||||
const byte idxOutRngMax = 255;
|
const byte IdxOutRngMax = 255;
|
||||||
|
|
||||||
ulong idxs = 0ul;
|
ulong idxs = 0ul;
|
||||||
|
|
||||||
for (int cnt = 1; cnt <= 8; cnt++)
|
for (int cnt = 1; cnt <= 8; cnt++)
|
||||||
{
|
{
|
||||||
ulong idxInRng = TestContext.CurrentContext.Random.NextByte(idxInRngMin, idxInRngMax);
|
ulong idxInRng = TestContext.CurrentContext.Random.NextByte(IdxInRngMin, idxInRngMax);
|
||||||
ulong idxOutRng = TestContext.CurrentContext.Random.NextByte(idxOutRngMin, idxOutRngMax);
|
ulong idxOutRng = TestContext.CurrentContext.Random.NextByte(idxOutRngMin, IdxOutRngMax);
|
||||||
|
|
||||||
ulong idx = TestContext.CurrentContext.Random.NextBool() ? idxInRng : idxOutRng;
|
ulong idx = TestContext.CurrentContext.Random.NextBool() ? idxInRng : idxOutRng;
|
||||||
|
|
||||||
|
@ -314,4 +314,4 @@ namespace Ryujinx.Tests.Cpu
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
using LibHac.Common;
|
using LibHac.Common;
|
||||||
using LibHac.Ns;
|
|
||||||
using LibHac.Fs;
|
using LibHac.Fs;
|
||||||
using LibHac.Fs.Fsa;
|
using LibHac.Fs.Fsa;
|
||||||
using LibHac.FsSystem;
|
using LibHac.FsSystem;
|
||||||
using LibHac.Loader;
|
using LibHac.Loader;
|
||||||
|
using LibHac.Ns;
|
||||||
using LibHac.Tools.Fs;
|
using LibHac.Tools.Fs;
|
||||||
using LibHac.Tools.FsSystem;
|
using LibHac.Tools.FsSystem;
|
||||||
using LibHac.Tools.FsSystem.NcaUtils;
|
using LibHac.Tools.FsSystem.NcaUtils;
|
||||||
|
@ -146,9 +146,9 @@ namespace Ryujinx.Ui.App.Common
|
||||||
return string.Empty;
|
return string.Empty;
|
||||||
}
|
}
|
||||||
|
|
||||||
const string mainExeFs = "main";
|
const string MainExeFs = "main";
|
||||||
|
|
||||||
if (!codeFs.FileExists($"/{mainExeFs}"))
|
if (!codeFs.FileExists($"/{MainExeFs}"))
|
||||||
{
|
{
|
||||||
Logger.Error?.Print(LogClass.Loader, "No main binary ExeFS found in ExeFS");
|
Logger.Error?.Print(LogClass.Loader, "No main binary ExeFS found in ExeFS");
|
||||||
|
|
||||||
|
@ -157,12 +157,12 @@ namespace Ryujinx.Ui.App.Common
|
||||||
|
|
||||||
using var nsoFile = new UniqueRef<IFile>();
|
using var nsoFile = new UniqueRef<IFile>();
|
||||||
|
|
||||||
codeFs.OpenFile(ref nsoFile.Ref, $"/{mainExeFs}".ToU8Span(), OpenMode.Read).ThrowIfFailure();
|
codeFs.OpenFile(ref nsoFile.Ref, $"/{MainExeFs}".ToU8Span(), OpenMode.Read).ThrowIfFailure();
|
||||||
|
|
||||||
NsoReader reader = new NsoReader();
|
NsoReader reader = new NsoReader();
|
||||||
reader.Initialize(nsoFile.Release().AsStorage().AsFile(OpenMode.Read)).ThrowIfFailure();
|
reader.Initialize(nsoFile.Release().AsStorage().AsFile(OpenMode.Read)).ThrowIfFailure();
|
||||||
|
|
||||||
return BitConverter.ToString(reader.Header.ModuleId.ItemsRo.ToArray()).Replace("-", "").ToUpper()[..16];
|
return BitConverter.ToString(reader.Header.ModuleId.ItemsRo.ToArray()).Replace("-", "").ToUpper()[..16];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,9 +18,9 @@ using Ryujinx.Ui.Common.Configuration;
|
||||||
using Ryujinx.Ui.Common.Configuration.System;
|
using Ryujinx.Ui.Common.Configuration.System;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Text.Json;
|
using System.Text.Json;
|
||||||
|
|
|
@ -389,12 +389,12 @@ namespace Ryujinx.Ui.Widgets
|
||||||
|
|
||||||
using (destHandle)
|
using (destHandle)
|
||||||
{
|
{
|
||||||
const int maxBufferSize = 1024 * 1024;
|
const int MaxBufferSize = 1024 * 1024;
|
||||||
|
|
||||||
rc = fs.GetFileSize(out long fileSize, sourceHandle);
|
rc = fs.GetFileSize(out long fileSize, sourceHandle);
|
||||||
if (rc.IsFailure()) return rc;
|
if (rc.IsFailure()) return rc;
|
||||||
|
|
||||||
int bufferSize = (int)Math.Min(maxBufferSize, fileSize);
|
int bufferSize = (int)Math.Min(MaxBufferSize, fileSize);
|
||||||
|
|
||||||
byte[] buffer = ArrayPool<byte>.Shared.Rent(bufferSize);
|
byte[] buffer = ArrayPool<byte>.Shared.Rent(bufferSize);
|
||||||
try
|
try
|
||||||
|
|
Loading…
Reference in a new issue