mirror of
				https://git.ryujinx.app/ryubing/ryujinx.git
				synced 2025-10-24 23:24:21 +00:00 
			
		
		
		
	Revert "Structural and Memory Safety Improvements, Analyzer Cleanup (ryubing/ryujinx!47)"
This reverts merge request !47
This commit is contained in:
		| @@ -45,10 +45,10 @@ dotnet_separate_import_directive_groups = false | ||||
| dotnet_sort_system_directives_first = false | ||||
|  | ||||
| # this. and Me. preferences | ||||
| dotnet_style_qualification_for_event = false:suggestion | ||||
| dotnet_style_qualification_for_field = false:suggestion | ||||
| dotnet_style_qualification_for_method = false:suggestion | ||||
| dotnet_style_qualification_for_property = false:suggestion | ||||
| dotnet_style_qualification_for_event = false:silent | ||||
| dotnet_style_qualification_for_field = false:silent | ||||
| dotnet_style_qualification_for_method = false:silent | ||||
| dotnet_style_qualification_for_property = false:silent | ||||
|  | ||||
| # Language keywords vs BCL types preferences | ||||
| dotnet_style_predefined_type_for_locals_parameters_members = true:silent | ||||
| @@ -257,14 +257,12 @@ csharp_prefer_system_threading_lock = true:suggestion | ||||
| dotnet_diagnostic.CA1069.severity = none  # CA1069: Enums values should not be duplicated | ||||
| # Disable Collection initialization can be simplified | ||||
| dotnet_diagnostic.IDE0028.severity = none | ||||
| dotnet_diagnostic.IDE0079.severity = none  # IDE0079: Remove unnecessary suppression | ||||
| dotnet_diagnostic.IDE0130.severity = none  # IDE0130: Namespace does not match folder structure | ||||
| dotnet_diagnostic.IDE0300.severity = none | ||||
| dotnet_diagnostic.IDE0301.severity = none | ||||
| dotnet_diagnostic.IDE0302.severity = none | ||||
| dotnet_diagnostic.IDE0305.severity = none | ||||
| dotnet_diagnostic.CS9113.severity = none  # CS9113: Parameter 'value' is unread | ||||
| dotnet_diagnostic.CS0649.severity = none  # CS0649: Field is never assigned to, and will always have its default value | ||||
| dotnet_diagnostic.IDE0130.severity = none  # IDE0130: Namespace does not match folder structure | ||||
|  | ||||
| [src/Ryujinx/UI/ViewModels/**.cs] | ||||
| # Disable "mark members as static" rule for ViewModels | ||||
|   | ||||
| @@ -1129,6 +1129,7 @@ namespace ARMeilleure.CodeGen.Arm64 | ||||
|             }; | ||||
|         } | ||||
|  | ||||
| #pragma warning disable IDE0051 // Remove unused private member | ||||
|         private void WriteInt16(short value) | ||||
|         { | ||||
|             WriteUInt16((ushort)value); | ||||
| @@ -1143,6 +1144,7 @@ namespace ARMeilleure.CodeGen.Arm64 | ||||
|         { | ||||
|             _stream.WriteByte(value); | ||||
|         } | ||||
| #pragma warning restore IDE0051 | ||||
|  | ||||
|         private void WriteUInt16(ushort value) | ||||
|         { | ||||
|   | ||||
| @@ -1570,11 +1570,13 @@ namespace ARMeilleure.CodeGen.Arm64 | ||||
|             Debug.Assert(op1.Type == op3.Type); | ||||
|         } | ||||
|  | ||||
| #pragma warning disable IDE0051 // Remove unused private member | ||||
|         private static void EnsureSameType(Operand op1, Operand op2, Operand op3, Operand op4) | ||||
|         { | ||||
|             Debug.Assert(op1.Type == op2.Type); | ||||
|             Debug.Assert(op1.Type == op3.Type); | ||||
|             Debug.Assert(op1.Type == op4.Type); | ||||
|         } | ||||
| #pragma warning restore IDE0051 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| using System; | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
|  | ||||
| namespace ARMeilleure.CodeGen.X86 | ||||
| { | ||||
|   | ||||
| @@ -20,12 +20,12 @@ namespace ARMeilleure.CodeGen.X86 | ||||
|         { | ||||
|             if (GetCurrentCallConv() == CallConvName.Windows) | ||||
|             { | ||||
|  | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|                 return (1 << (int)X86Register.Rax) | | ||||
|                        (1 << (int)X86Register.Rcx) | | ||||
|                        (1 << (int)X86Register.Rdx) | | ||||
|                        (1 << (int)X86Register.R8) | | ||||
|                        (1 << (int)X86Register.R9) | | ||||
|                        (1 << (int)X86Register.R8)  | | ||||
|                        (1 << (int)X86Register.R9)  | | ||||
|                        (1 << (int)X86Register.R10) | | ||||
|                        (1 << (int)X86Register.R11); | ||||
|             } | ||||
| @@ -36,11 +36,11 @@ namespace ARMeilleure.CodeGen.X86 | ||||
|                        (1 << (int)X86Register.Rdx) | | ||||
|                        (1 << (int)X86Register.Rsi) | | ||||
|                        (1 << (int)X86Register.Rdi) | | ||||
|                        (1 << (int)X86Register.R8) | | ||||
|                        (1 << (int)X86Register.R9) | | ||||
|                        (1 << (int)X86Register.R8)  | | ||||
|                        (1 << (int)X86Register.R9)  | | ||||
|                        (1 << (int)X86Register.R10) | | ||||
|                        (1 << (int)X86Register.R11); | ||||
|  | ||||
| #pragma warning restore IDE0055 | ||||
|             } | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -2,6 +2,7 @@ using ARMeilleure.CodeGen.RegisterAllocators; | ||||
| using ARMeilleure.IntermediateRepresentation; | ||||
| using Microsoft.IO; | ||||
| using Ryujinx.Common.Memory; | ||||
| using System.IO; | ||||
| using System.Numerics; | ||||
|  | ||||
| namespace ARMeilleure.CodeGen.X86 | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
|  | ||||
| namespace ARMeilleure.CodeGen.X86 | ||||
| { | ||||
|     enum X86Register | ||||
|   | ||||
| @@ -8,8 +8,8 @@ namespace ARMeilleure.Instructions | ||||
|     static class CryptoHelper | ||||
|     { | ||||
|         #region "LookUp Tables" | ||||
|  | ||||
|         private static ReadOnlySpan<byte> SBox => | ||||
| #pragma warning disable IDE1006 // Naming rule violation | ||||
|         private static ReadOnlySpan<byte> _sBox => | ||||
|         [ | ||||
|             0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76, | ||||
|             0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0, | ||||
| @@ -29,7 +29,7 @@ namespace ARMeilleure.Instructions | ||||
|             0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16 | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> InvSBox => | ||||
|         private static ReadOnlySpan<byte> _invSBox => | ||||
|         [ | ||||
|             0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb, | ||||
|             0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb, | ||||
| @@ -49,7 +49,7 @@ namespace ARMeilleure.Instructions | ||||
|             0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> GfMul02 => | ||||
|         private static ReadOnlySpan<byte> _gfMul02 => | ||||
|         [ | ||||
|             0x00, 0x02, 0x04, 0x06, 0x08, 0x0a, 0x0c, 0x0e, 0x10, 0x12, 0x14, 0x16, 0x18, 0x1a, 0x1c, 0x1e, | ||||
|             0x20, 0x22, 0x24, 0x26, 0x28, 0x2a, 0x2c, 0x2e, 0x30, 0x32, 0x34, 0x36, 0x38, 0x3a, 0x3c, 0x3e, | ||||
| @@ -69,7 +69,7 @@ namespace ARMeilleure.Instructions | ||||
|             0xfb, 0xf9, 0xff, 0xfd, 0xf3, 0xf1, 0xf7, 0xf5, 0xeb, 0xe9, 0xef, 0xed, 0xe3, 0xe1, 0xe7, 0xe5 | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> GfMul03 => | ||||
|         private static ReadOnlySpan<byte> _gfMul03 => | ||||
|         [ | ||||
|             0x00, 0x03, 0x06, 0x05, 0x0c, 0x0f, 0x0a, 0x09, 0x18, 0x1b, 0x1e, 0x1d, 0x14, 0x17, 0x12, 0x11, | ||||
|             0x30, 0x33, 0x36, 0x35, 0x3c, 0x3f, 0x3a, 0x39, 0x28, 0x2b, 0x2e, 0x2d, 0x24, 0x27, 0x22, 0x21, | ||||
| @@ -89,7 +89,7 @@ namespace ARMeilleure.Instructions | ||||
|             0x0b, 0x08, 0x0d, 0x0e, 0x07, 0x04, 0x01, 0x02, 0x13, 0x10, 0x15, 0x16, 0x1f, 0x1c, 0x19, 0x1a | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> GfMul09 => | ||||
|         private static ReadOnlySpan<byte> _gfMul09 => | ||||
|         [ | ||||
|             0x00, 0x09, 0x12, 0x1b, 0x24, 0x2d, 0x36, 0x3f, 0x48, 0x41, 0x5a, 0x53, 0x6c, 0x65, 0x7e, 0x77, | ||||
|             0x90, 0x99, 0x82, 0x8b, 0xb4, 0xbd, 0xa6, 0xaf, 0xd8, 0xd1, 0xca, 0xc3, 0xfc, 0xf5, 0xee, 0xe7, | ||||
| @@ -109,7 +109,7 @@ namespace ARMeilleure.Instructions | ||||
|             0x31, 0x38, 0x23, 0x2a, 0x15, 0x1c, 0x07, 0x0e, 0x79, 0x70, 0x6b, 0x62, 0x5d, 0x54, 0x4f, 0x46 | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> GfMul0B => | ||||
|         private static ReadOnlySpan<byte> _gfMul0B => | ||||
|         [ | ||||
|             0x00, 0x0b, 0x16, 0x1d, 0x2c, 0x27, 0x3a, 0x31, 0x58, 0x53, 0x4e, 0x45, 0x74, 0x7f, 0x62, 0x69, | ||||
|             0xb0, 0xbb, 0xa6, 0xad, 0x9c, 0x97, 0x8a, 0x81, 0xe8, 0xe3, 0xfe, 0xf5, 0xc4, 0xcf, 0xd2, 0xd9, | ||||
| @@ -129,7 +129,7 @@ namespace ARMeilleure.Instructions | ||||
|             0xca, 0xc1, 0xdc, 0xd7, 0xe6, 0xed, 0xf0, 0xfb, 0x92, 0x99, 0x84, 0x8f, 0xbe, 0xb5, 0xa8, 0xa3 | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> GfMul0D => | ||||
|         private static ReadOnlySpan<byte> _gfMul0D => | ||||
|         [ | ||||
|             0x00, 0x0d, 0x1a, 0x17, 0x34, 0x39, 0x2e, 0x23, 0x68, 0x65, 0x72, 0x7f, 0x5c, 0x51, 0x46, 0x4b, | ||||
|             0xd0, 0xdd, 0xca, 0xc7, 0xe4, 0xe9, 0xfe, 0xf3, 0xb8, 0xb5, 0xa2, 0xaf, 0x8c, 0x81, 0x96, 0x9b, | ||||
| @@ -149,7 +149,7 @@ namespace ARMeilleure.Instructions | ||||
|             0xdc, 0xd1, 0xc6, 0xcb, 0xe8, 0xe5, 0xf2, 0xff, 0xb4, 0xb9, 0xae, 0xa3, 0x80, 0x8d, 0x9a, 0x97 | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> GfMul0E => | ||||
|         private static ReadOnlySpan<byte> _gfMul0E => | ||||
|         [ | ||||
|             0x00, 0x0e, 0x1c, 0x12, 0x38, 0x36, 0x24, 0x2a, 0x70, 0x7e, 0x6c, 0x62, 0x48, 0x46, 0x54, 0x5a, | ||||
|             0xe0, 0xee, 0xfc, 0xf2, 0xd8, 0xd6, 0xc4, 0xca, 0x90, 0x9e, 0x8c, 0x82, 0xa8, 0xa6, 0xb4, 0xba, | ||||
| @@ -169,16 +169,16 @@ namespace ARMeilleure.Instructions | ||||
|             0xd7, 0xd9, 0xcb, 0xc5, 0xef, 0xe1, 0xf3, 0xfd, 0xa7, 0xa9, 0xbb, 0xb5, 0x9f, 0x91, 0x83, 0x8d | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> SrPerm => | ||||
|         private static ReadOnlySpan<byte> _srPerm => | ||||
|         [ | ||||
|             0, 13, 10, 7, 4, 1, 14, 11, 8, 5, 2, 15, 12, 9, 6, 3 | ||||
|         ]; | ||||
|  | ||||
|         private static ReadOnlySpan<byte> IsrPerm => | ||||
|         private static ReadOnlySpan<byte> _isrPerm => | ||||
|         [ | ||||
|             0, 5, 10, 15, 4, 9, 14, 3, 8, 13, 2, 7, 12, 1, 6, 11 | ||||
|         ]; | ||||
|  | ||||
| #pragma warning restore IDE1006 | ||||
|         #endregion | ||||
|  | ||||
|         public static V128 AesInvMixColumns(V128 op) | ||||
| @@ -195,10 +195,10 @@ namespace ARMeilleure.Instructions | ||||
|                 byte row2 = inState[idx + 2]; // C, G, K, O: [row2, col0-col3] | ||||
|                 byte row3 = inState[idx + 3]; // D, H, L, P: [row3, col0-col3] | ||||
|  | ||||
|                 outState[idx + 0] = (byte)((uint)GfMul0E[row0] ^ GfMul0B[row1] ^ GfMul0D[row2] ^ GfMul09[row3]); | ||||
|                 outState[idx + 1] = (byte)((uint)GfMul09[row0] ^ GfMul0E[row1] ^ GfMul0B[row2] ^ GfMul0D[row3]); | ||||
|                 outState[idx + 2] = (byte)((uint)GfMul0D[row0] ^ GfMul09[row1] ^ GfMul0E[row2] ^ GfMul0B[row3]); | ||||
|                 outState[idx + 3] = (byte)((uint)GfMul0B[row0] ^ GfMul0D[row1] ^ GfMul09[row2] ^ GfMul0E[row3]); | ||||
|                 outState[idx + 0] = (byte)((uint)_gfMul0E[row0] ^ _gfMul0B[row1] ^ _gfMul0D[row2] ^ _gfMul09[row3]); | ||||
|                 outState[idx + 1] = (byte)((uint)_gfMul09[row0] ^ _gfMul0E[row1] ^ _gfMul0B[row2] ^ _gfMul0D[row3]); | ||||
|                 outState[idx + 2] = (byte)((uint)_gfMul0D[row0] ^ _gfMul09[row1] ^ _gfMul0E[row2] ^ _gfMul0B[row3]); | ||||
|                 outState[idx + 3] = (byte)((uint)_gfMul0B[row0] ^ _gfMul0D[row1] ^ _gfMul09[row2] ^ _gfMul0E[row3]); | ||||
|             } | ||||
|  | ||||
|             return new V128(outState); | ||||
| @@ -211,7 +211,7 @@ namespace ARMeilleure.Instructions | ||||
|  | ||||
|             for (int idx = 0; idx <= 15; idx++) | ||||
|             { | ||||
|                 outState[IsrPerm[idx]] = inState[idx]; | ||||
|                 outState[_isrPerm[idx]] = inState[idx]; | ||||
|             } | ||||
|  | ||||
|             return new V128(outState); | ||||
| @@ -224,7 +224,7 @@ namespace ARMeilleure.Instructions | ||||
|  | ||||
|             for (int idx = 0; idx <= 15; idx++) | ||||
|             { | ||||
|                 outState[idx] = InvSBox[inState[idx]]; | ||||
|                 outState[idx] = _invSBox[inState[idx]]; | ||||
|             } | ||||
|  | ||||
|             return new V128(outState); | ||||
| @@ -244,10 +244,10 @@ namespace ARMeilleure.Instructions | ||||
|                 byte row2 = inState[idx + 2]; // C, G, K, O: [row2, col0-col3] | ||||
|                 byte row3 = inState[idx + 3]; // D, H, L, P: [row3, col0-col3] | ||||
|  | ||||
|                 outState[idx + 0] = (byte)((uint)GfMul02[row0] ^ GfMul03[row1] ^ row2 ^ row3); | ||||
|                 outState[idx + 1] = (byte)((uint)row0 ^ GfMul02[row1] ^ GfMul03[row2] ^ row3); | ||||
|                 outState[idx + 2] = (byte)((uint)row0 ^ row1 ^ GfMul02[row2] ^ GfMul03[row3]); | ||||
|                 outState[idx + 3] = (byte)((uint)GfMul03[row0] ^ row1 ^ row2 ^ GfMul02[row3]); | ||||
|                 outState[idx + 0] = (byte)((uint)_gfMul02[row0] ^ _gfMul03[row1] ^ row2 ^ row3); | ||||
|                 outState[idx + 1] = (byte)((uint)row0 ^ _gfMul02[row1] ^ _gfMul03[row2] ^ row3); | ||||
|                 outState[idx + 2] = (byte)((uint)row0 ^ row1 ^ _gfMul02[row2] ^ _gfMul03[row3]); | ||||
|                 outState[idx + 3] = (byte)((uint)_gfMul03[row0] ^ row1 ^ row2 ^ _gfMul02[row3]); | ||||
|             } | ||||
|  | ||||
|             return new V128(outState); | ||||
| @@ -260,7 +260,7 @@ namespace ARMeilleure.Instructions | ||||
|  | ||||
|             for (int idx = 0; idx <= 15; idx++) | ||||
|             { | ||||
|                 outState[SrPerm[idx]] = inState[idx]; | ||||
|                 outState[_srPerm[idx]] = inState[idx]; | ||||
|             } | ||||
|  | ||||
|             return new V128(outState); | ||||
| @@ -273,7 +273,7 @@ namespace ARMeilleure.Instructions | ||||
|  | ||||
|             for (int idx = 0; idx <= 15; idx++) | ||||
|             { | ||||
|                 outState[idx] = SBox[inState[idx]]; | ||||
|                 outState[idx] = _sBox[inState[idx]]; | ||||
|             } | ||||
|  | ||||
|             return new V128(outState); | ||||
|   | ||||
| @@ -2,6 +2,7 @@ using ARMeilleure.Decoders; | ||||
| using ARMeilleure.IntermediateRepresentation; | ||||
| using ARMeilleure.Translation; | ||||
| using System; | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
|   | ||||
| @@ -11,10 +11,11 @@ using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper32; | ||||
| using static ARMeilleure.IntermediateRepresentation.Operand.Factory; | ||||
| using Func2I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     using Func2I = Func<Operand, Operand, Operand>; | ||||
|  | ||||
|     static partial class InstEmit | ||||
|     { | ||||
|         public static void Abs_S(ArmEmitterContext context) | ||||
|   | ||||
| @@ -2,13 +2,15 @@ using ARMeilleure.Decoders; | ||||
| using ARMeilleure.IntermediateRepresentation; | ||||
| using ARMeilleure.State; | ||||
| using ARMeilleure.Translation; | ||||
| using System; | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper; | ||||
| using static ARMeilleure.IntermediateRepresentation.Operand.Factory; | ||||
| using Func2I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     using Func2I = Func<Operand, Operand, Operand>; | ||||
|  | ||||
|     static partial class InstEmit | ||||
|     { | ||||
|         public static void Cmeq_S(ArmEmitterContext context) | ||||
|   | ||||
| @@ -2,15 +2,17 @@ using ARMeilleure.Decoders; | ||||
| using ARMeilleure.IntermediateRepresentation; | ||||
| using ARMeilleure.State; | ||||
| using ARMeilleure.Translation; | ||||
| using System; | ||||
|  | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper32; | ||||
| using static ARMeilleure.IntermediateRepresentation.Operand.Factory; | ||||
| using Func2I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     using Func2I = Func<Operand, Operand, Operand>; | ||||
|  | ||||
|     static partial class InstEmit32 | ||||
|     { | ||||
|         public static void Vceq_V(ArmEmitterContext context) | ||||
|   | ||||
| @@ -8,10 +8,11 @@ using System.Reflection; | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper; | ||||
| using static ARMeilleure.IntermediateRepresentation.Operand.Factory; | ||||
| using Func1I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     using Func1I = Func<Operand, Operand>; | ||||
|  | ||||
|     static partial class InstEmit | ||||
|     { | ||||
|         public static void Fcvt_S(ArmEmitterContext context) | ||||
|   | ||||
| @@ -8,12 +8,13 @@ using System.Diagnostics; | ||||
| using System.Reflection; | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| using static ARMeilleure.IntermediateRepresentation.Operand.Factory; | ||||
| using Func1I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
| using Func2I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
| using Func3I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     using Func1I = Func<Operand, Operand>; | ||||
|     using Func2I = Func<Operand, Operand, Operand>; | ||||
|     using Func3I = Func<Operand, Operand, Operand, Operand>; | ||||
|  | ||||
|     static class InstEmitSimdHelper | ||||
|     { | ||||
|         #region "Masks" | ||||
|   | ||||
| @@ -7,12 +7,13 @@ using System.Reflection; | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper; | ||||
| using static ARMeilleure.IntermediateRepresentation.Operand.Factory; | ||||
| using Func1I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
| using Func2I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
| using Func3I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     using Func1I = Func<Operand, Operand>; | ||||
|     using Func2I = Func<Operand, Operand, Operand>; | ||||
|     using Func3I = Func<Operand, Operand, Operand, Operand>; | ||||
|  | ||||
|     static class InstEmitSimdHelper32 | ||||
|     { | ||||
|         public static (int, int) GetQuadwordAndSubindex(int index, RegisterSize size) | ||||
|   | ||||
| @@ -7,12 +7,13 @@ using System.Diagnostics; | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper; | ||||
| using static ARMeilleure.IntermediateRepresentation.Operand.Factory; | ||||
| using Func1I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
| using Func2I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
| using Func3I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     using Func1I = Func<Operand, Operand>; | ||||
|     using Func2I = Func<Operand, Operand, Operand>; | ||||
|     using Func3I = Func<Operand, Operand, Operand, Operand>; | ||||
|  | ||||
|     static class InstEmitSimdHelper32Arm64 | ||||
|     { | ||||
|         // Intrinsic Helpers | ||||
|   | ||||
| @@ -40,36 +40,34 @@ namespace ARMeilleure.Instructions | ||||
|  | ||||
|             long offset = 0; | ||||
|  | ||||
|             for (int rep = 0; rep < op.Reps; rep++) | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|             for (int rep   = 0; rep   < op.Reps;   rep++) | ||||
|             for (int elem  = 0; elem  < op.Elems;  elem++) | ||||
|             for (int sElem = 0; sElem < op.SElems; sElem++) | ||||
|             { | ||||
|                 for (int elem = 0; elem < op.Elems; elem++) | ||||
|                 int rtt = (op.Rt + rep + sElem) & 0x1f; | ||||
|  | ||||
|                 Operand tt = GetVec(rtt); | ||||
|  | ||||
|                 Operand address = context.Add(n, Const(offset)); | ||||
|  | ||||
|                 if (isLoad) | ||||
|                 { | ||||
|                     for (int sElem = 0; sElem < op.SElems; sElem++) | ||||
|                     EmitLoadSimd(context, address, tt, rtt, elem, op.Size); | ||||
|  | ||||
|                     if (op.RegisterSize == RegisterSize.Simd64 && elem == op.Elems - 1) | ||||
|                     { | ||||
|                         int rtt = (op.Rt + rep + sElem) & 0x1f; | ||||
|  | ||||
|                         Operand tt = GetVec(rtt); | ||||
|  | ||||
|                         Operand address = context.Add(n, Const(offset)); | ||||
|  | ||||
|                         if (isLoad) | ||||
|                         { | ||||
|                             EmitLoadSimd(context, address, tt, rtt, elem, op.Size); | ||||
|  | ||||
|                             if (op.RegisterSize == RegisterSize.Simd64 && elem == op.Elems - 1) | ||||
|                             { | ||||
|                                 context.Copy(tt, context.VectorZeroUpper64(tt)); | ||||
|                             } | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             EmitStoreSimd(context, address, rtt, elem, op.Size); | ||||
|                         } | ||||
|  | ||||
|                         offset += 1 << op.Size; | ||||
|                         context.Copy(tt, context.VectorZeroUpper64(tt)); | ||||
|                     } | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     EmitStoreSimd(context, address, rtt, elem, op.Size); | ||||
|                 } | ||||
|  | ||||
|                 offset += 1 << op.Size; | ||||
|             } | ||||
| #pragma warning restore IDE0055 | ||||
|  | ||||
|             if (op.WBack) | ||||
|             { | ||||
|   | ||||
| @@ -9,10 +9,11 @@ using System.Reflection; | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| using static ARMeilleure.Instructions.InstEmitSimdHelper; | ||||
| using static ARMeilleure.IntermediateRepresentation.Operand.Factory; | ||||
| using Func2I = System.Func<ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand, ARMeilleure.IntermediateRepresentation.Operand>; | ||||
|  | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     using Func2I = Func<Operand, Operand, Operand>; | ||||
|  | ||||
|     static partial class InstEmit | ||||
|     { | ||||
|         #region "Masks" | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| using System; | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
|  | ||||
| namespace ARMeilleure.IntermediateRepresentation | ||||
| { | ||||
|   | ||||
| @@ -7,9 +7,10 @@ namespace ARMeilleure.IntermediateRepresentation | ||||
|     { | ||||
|         private struct Data | ||||
|         { | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|             public byte Kind; | ||||
|             public byte Type; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|             public byte Scale; | ||||
|             public Operand BaseAddress; | ||||
|             public Operand Index; | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| using Arm64HardwareCapabilities = ARMeilleure.CodeGen.Arm64.HardwareCapabilities; | ||||
| using X86HardwareCapabilities = ARMeilleure.CodeGen.X86.HardwareCapabilities; | ||||
|  | ||||
| namespace ARMeilleure | ||||
| { | ||||
|     using Arm64HardwareCapabilities = ARMeilleure.CodeGen.Arm64.HardwareCapabilities; | ||||
|     using X86HardwareCapabilities = ARMeilleure.CodeGen.X86.HardwareCapabilities; | ||||
|  | ||||
|     public static class Optimizations | ||||
|     { | ||||
|         // low-core count PPTC | ||||
|   | ||||
| @@ -218,28 +218,18 @@ namespace ARMeilleure.Translation | ||||
|             { | ||||
|                 switch (condition) | ||||
|                 { | ||||
|  | ||||
|                     case Condition.Eq: | ||||
|                         return ICompareEqual(n, m); | ||||
|                     case Condition.Ne: | ||||
|                         return ICompareNotEqual(n, m); | ||||
|                     case Condition.GeUn: | ||||
|                         return ICompareGreaterOrEqualUI(n, m); | ||||
|                     case Condition.LtUn: | ||||
|                         return ICompareLessUI(n, m); | ||||
|                     case Condition.GtUn: | ||||
|                         return ICompareGreaterUI(n, m); | ||||
|                     case Condition.LeUn: | ||||
|                         return ICompareLessOrEqualUI(n, m); | ||||
|                     case Condition.Ge: | ||||
|                         return ICompareGreaterOrEqual(n, m); | ||||
|                     case Condition.Lt: | ||||
|                         return ICompareLess(n, m); | ||||
|                     case Condition.Gt: | ||||
|                         return ICompareGreater(n, m); | ||||
|                     case Condition.Le: | ||||
|                         return ICompareLessOrEqual(n, m); | ||||
|  | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|                     case Condition.Eq:   return ICompareEqual           (n, m); | ||||
|                     case Condition.Ne:   return ICompareNotEqual        (n, m); | ||||
|                     case Condition.GeUn: return ICompareGreaterOrEqualUI(n, m); | ||||
|                     case Condition.LtUn: return ICompareLessUI          (n, m); | ||||
|                     case Condition.GtUn: return ICompareGreaterUI       (n, m); | ||||
|                     case Condition.LeUn: return ICompareLessOrEqualUI   (n, m); | ||||
|                     case Condition.Ge:   return ICompareGreaterOrEqual  (n, m); | ||||
|                     case Condition.Lt:   return ICompareLess            (n, m); | ||||
|                     case Condition.Gt:   return ICompareGreater         (n, m); | ||||
|                     case Condition.Le:   return ICompareLessOrEqual     (n, m); | ||||
| #pragma warning restore IDE0055 | ||||
|                 } | ||||
|             } | ||||
|             else if (cmpName == InstName.Adds && _optOpLastCompare is IOpCodeAluImm op) | ||||
| @@ -264,20 +254,14 @@ namespace ARMeilleure.Translation | ||||
|  | ||||
|                 switch (condition) | ||||
|                 { | ||||
|  | ||||
|                     case Condition.Eq: | ||||
|                         return ICompareEqual(n, m); | ||||
|                     case Condition.Ne: | ||||
|                         return ICompareNotEqual(n, m); | ||||
|                     case Condition.Ge: | ||||
|                         return ICompareGreaterOrEqual(n, m); | ||||
|                     case Condition.Lt: | ||||
|                         return ICompareLess(n, m); | ||||
|                     case Condition.Gt: | ||||
|                         return ICompareGreater(n, m); | ||||
|                     case Condition.Le: | ||||
|                         return ICompareLessOrEqual(n, m); | ||||
|  | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|                     case Condition.Eq: return ICompareEqual         (n, m); | ||||
|                     case Condition.Ne: return ICompareNotEqual      (n, m); | ||||
|                     case Condition.Ge: return ICompareGreaterOrEqual(n, m); | ||||
|                     case Condition.Lt: return ICompareLess          (n, m); | ||||
|                     case Condition.Gt: return ICompareGreater       (n, m); | ||||
|                     case Condition.Le: return ICompareLessOrEqual   (n, m); | ||||
| #pragma warning restore IDE0055 | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|   | ||||
| @@ -22,11 +22,12 @@ using System.Runtime.CompilerServices; | ||||
| using System.Runtime.InteropServices; | ||||
| using System.Threading; | ||||
| using static ARMeilleure.Translation.PTC.PtcFormatter; | ||||
| using Arm64HardwareCapabilities = ARMeilleure.CodeGen.Arm64.HardwareCapabilities; | ||||
| using X86HardwareCapabilities = ARMeilleure.CodeGen.X86.HardwareCapabilities; | ||||
|  | ||||
| namespace ARMeilleure.Translation.PTC | ||||
| { | ||||
|     using Arm64HardwareCapabilities = CodeGen.Arm64.HardwareCapabilities; | ||||
|     using X86HardwareCapabilities = CodeGen.X86.HardwareCapabilities; | ||||
|  | ||||
|     class Ptc : IPtcLoadState | ||||
|     { | ||||
|         private const string OuterHeaderMagicString = "PTCohd\0\0"; | ||||
|   | ||||
| @@ -297,20 +297,12 @@ namespace ARMeilleure.Translation | ||||
|  | ||||
|             switch (register.Type) | ||||
|             { | ||||
|  | ||||
|                 case RegisterType.Flag: | ||||
|                     intMask = (1L << RegsCount) << register.Index; | ||||
|                     break; | ||||
|                 case RegisterType.Integer: | ||||
|                     intMask = 1L << register.Index; | ||||
|                     break; | ||||
|                 case RegisterType.FpFlag: | ||||
|                     vecMask = (1L << RegsCount) << register.Index; | ||||
|                     break; | ||||
|                 case RegisterType.Vector: | ||||
|                     vecMask = 1L << register.Index; | ||||
|                     break; | ||||
|  | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|                 case RegisterType.Flag:    intMask = (1L << RegsCount) << register.Index; break; | ||||
|                 case RegisterType.Integer: intMask =  1L               << register.Index; break; | ||||
|                 case RegisterType.FpFlag:  vecMask = (1L << RegsCount) << register.Index; break; | ||||
|                 case RegisterType.Vector:  vecMask =  1L               << register.Index; break; | ||||
| #pragma warning restore IDE0055 | ||||
|             } | ||||
|  | ||||
|             return new RegisterMask(intMask, vecMask); | ||||
|   | ||||
| @@ -12,7 +12,7 @@ using static SDL2.SDL; | ||||
|  | ||||
| namespace Ryujinx.Audio.Backends.SDL2 | ||||
| { | ||||
|     public partial class SDL2HardwareDeviceDriver : IHardwareDeviceDriver | ||||
|     public class SDL2HardwareDeviceDriver : IHardwareDeviceDriver | ||||
|     { | ||||
|         private readonly ManualResetEvent _updateRequiredEvent; | ||||
|         private readonly ManualResetEvent _pauseEvent; | ||||
| @@ -22,36 +22,10 @@ namespace Ryujinx.Audio.Backends.SDL2 | ||||
|  | ||||
|         public float Volume { get; set; } | ||||
|  | ||||
|         // A safe method to get default audio information. | ||||
|         private static int GetDefaultAudioInfo(nint name, out SDL_AudioSpec spec, int isCapture) | ||||
|         { | ||||
|             int result; | ||||
|             spec = new SDL_AudioSpec(); | ||||
|             IntPtr specPtr = IntPtr.Zero; | ||||
|  | ||||
|             try | ||||
|             { | ||||
|                 // Reserve memory | ||||
|                 specPtr = Marshal.AllocHGlobal(Marshal.SizeOf<SDL_AudioSpec>()); | ||||
|                 // Call method | ||||
|                 result = SDL_GetDefaultAudioInfo(name, specPtr, isCapture); | ||||
|                 // Copy result to managed structure | ||||
|                 spec = Marshal.PtrToStructure<SDL_AudioSpec>(specPtr); | ||||
|             } | ||||
|             finally | ||||
|             { | ||||
|                 // Free the unmanaged memory to prevent memory leaks | ||||
|                 if (specPtr != IntPtr.Zero) | ||||
|                 { | ||||
|                     Marshal.FreeHGlobal(specPtr); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             return result; | ||||
|         } | ||||
|  | ||||
|         [LibraryImport("SDL2")] | ||||
|         private static partial int SDL_GetDefaultAudioInfo(nint name, nint spec, int isCapture); | ||||
|         // TODO: Add this to SDL2-CS | ||||
|         // NOTE: We use a DllImport here because of marshaling issue for spec. | ||||
|         [DllImport("SDL2")] | ||||
|         private static extern int SDL_GetDefaultAudioInfo(nint name, out SDL_AudioSpec spec, int isCapture); | ||||
|  | ||||
|         public SDL2HardwareDeviceDriver() | ||||
|         { | ||||
| @@ -61,7 +35,7 @@ namespace Ryujinx.Audio.Backends.SDL2 | ||||
|  | ||||
|             SDL2Driver.Instance.Initialize(); | ||||
|  | ||||
|             int res = GetDefaultAudioInfo(nint.Zero, out SDL_AudioSpec spec, 0); | ||||
|             int res = SDL_GetDefaultAudioInfo(nint.Zero, out SDL_AudioSpec spec, 0); | ||||
|  | ||||
|             if (res != 0) | ||||
|             { | ||||
|   | ||||
| @@ -23,7 +23,7 @@ namespace Ryujinx.Audio.Backends.SoundIo.Native | ||||
|         [UnmanagedFunctionPointer(CallingConvention.Cdecl)] | ||||
|         public delegate void JackCallbackDelegate(nint msg); | ||||
|  | ||||
|         [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|         [StructLayout(LayoutKind.Sequential)] | ||||
|         public struct SoundIoStruct | ||||
|         { | ||||
|             public nint UserData; | ||||
|   | ||||
| @@ -20,7 +20,9 @@ namespace Ryujinx.Audio.Renderer.Common | ||||
|         public uint Unknown24; | ||||
|         public uint RenderInfoSize; | ||||
|  | ||||
| #pragma warning disable IDE0051, CS0169 // Remove unused field | ||||
|         private Array4<int> _reserved; | ||||
| #pragma warning restore IDE0051, CS0169 | ||||
|  | ||||
|         public uint TotalSize; | ||||
|  | ||||
|   | ||||
| @@ -12,8 +12,9 @@ namespace Ryujinx.Audio.Renderer.Dsp | ||||
|         private const int SamplesPerFrame = 14; | ||||
|         private const int NibblesPerFrame = SamplesPerFrame + 2; | ||||
|         private const int BytesPerFrame = 8; | ||||
|  | ||||
| #pragma warning disable IDE0051 // Remove unused private member | ||||
|         private const int BitsPerFrame = BytesPerFrame * 8; | ||||
| #pragma warning restore IDE0051 | ||||
|  | ||||
|         [MethodImpl(MethodImplOptions.AggressiveInlining)] | ||||
|         public static uint GetAdpcmDataSize(int sampleCount) | ||||
|   | ||||
| @@ -41,10 +41,10 @@ namespace Ryujinx.Audio.Renderer.Server | ||||
|         private UpsamplerManager _upsamplerManager; | ||||
|         private bool _isActive; | ||||
|         private BehaviourContext _behaviourContext; | ||||
|  | ||||
| #pragma warning disable IDE0052 // Remove unread private member | ||||
|         private ulong _totalElapsedTicksUpdating; | ||||
|         private ulong _totalElapsedTicks; | ||||
|  | ||||
| #pragma warning restore IDE0052 | ||||
|         private int _sessionId; | ||||
|         private Memory<MemoryPoolState> _memoryPools; | ||||
|  | ||||
|   | ||||
| @@ -147,9 +147,9 @@ namespace Ryujinx.Common.Collections | ||||
|  | ||||
|             Queue<Node<TKey, TValue>> nodes = new(); | ||||
|  | ||||
|             if (Root != null) | ||||
|             if (this.Root != null) | ||||
|             { | ||||
|                 nodes.Enqueue(Root); | ||||
|                 nodes.Enqueue(this.Root); | ||||
|             } | ||||
|  | ||||
|             while (nodes.TryDequeue(out Node<TKey, TValue> node)) | ||||
| @@ -522,7 +522,7 @@ namespace Ryujinx.Common.Collections | ||||
|  | ||||
|         public void CopyTo(KeyValuePair<TKey, TValue>[] array, int arrayIndex) | ||||
|         { | ||||
|             if (arrayIndex < 0 || array.Length - arrayIndex < Count) | ||||
|             if (arrayIndex < 0 || array.Length - arrayIndex < this.Count) | ||||
|             { | ||||
|                 throw new ArgumentOutOfRangeException(nameof(arrayIndex)); | ||||
|             } | ||||
|   | ||||
| @@ -36,6 +36,8 @@ namespace Ryujinx.Common.Configuration | ||||
|             }; | ||||
|         } | ||||
|  | ||||
|  | ||||
|  | ||||
|         public static float ToFloatY(this AspectRatio aspectRatio) | ||||
|         { | ||||
|             return aspectRatio switch | ||||
|   | ||||
| @@ -18,6 +18,8 @@ namespace Ryujinx.Common.Configuration | ||||
|         public DirtyHack Hack => hack; | ||||
|         public int Value => value; | ||||
|  | ||||
|  | ||||
|  | ||||
|         public ulong Pack() => Raw.PackBitFields(PackedFormat); | ||||
|  | ||||
|         public static EnabledDirtyHack Unpack(ulong packedHack) | ||||
|   | ||||
| @@ -10,7 +10,7 @@ using System.Runtime.Intrinsics.X86; | ||||
|  | ||||
| namespace Ryujinx.Common | ||||
| { | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     [StructLayout(LayoutKind.Sequential)] | ||||
|     public struct Hash128(ulong low, ulong high) : IEquatable<Hash128> | ||||
|     { | ||||
|         public ulong Low = low; | ||||
|   | ||||
| @@ -219,34 +219,16 @@ namespace Ryujinx.Common.Logging | ||||
|             switch (logLevel) | ||||
|             { | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|                 case LogLevel.Debug: | ||||
|                     Debug =     enabled ? new Log(LogLevel.Debug) : new Log?(); | ||||
|                     break; | ||||
|                 case LogLevel.Info: | ||||
|                     Info =      enabled ? new Log(LogLevel.Info) : new Log?(); | ||||
|                     break; | ||||
|                 case LogLevel.Warning: | ||||
|                     Warning =   enabled ? new Log(LogLevel.Warning) : new Log?(); | ||||
|                     break; | ||||
|                 case LogLevel.Error: | ||||
|                     Error =     enabled ? new Log(LogLevel.Error) : new Log?(); | ||||
|                     break; | ||||
|                 case LogLevel.Guest: | ||||
|                     Guest =     enabled ? new Log(LogLevel.Guest) : new Log?(); | ||||
|                     break; | ||||
|                 case LogLevel.AccessLog: | ||||
|                     AccessLog = enabled ? new Log(LogLevel.AccessLog) : new Log?(); | ||||
|                     break; | ||||
|                 case LogLevel.Stub: | ||||
|                     Stub =      enabled ? new Log(LogLevel.Stub) : new Log?(); | ||||
|                     break; | ||||
|                 case LogLevel.Trace: | ||||
|                     Trace =     enabled ? new Log(LogLevel.Trace) : new Log?(); | ||||
|                     break; | ||||
|                 case LogLevel.Notice: | ||||
|                     break; | ||||
|                 default: | ||||
|                     throw new ArgumentException("Unknown Log Level", nameof(logLevel)); | ||||
|                 case LogLevel.Debug     : Debug     = enabled ? new Log(LogLevel.Debug)     : new Log?(); break; | ||||
|                 case LogLevel.Info      : Info      = enabled ? new Log(LogLevel.Info)      : new Log?(); break; | ||||
|                 case LogLevel.Warning   : Warning   = enabled ? new Log(LogLevel.Warning)   : new Log?(); break; | ||||
|                 case LogLevel.Error     : Error     = enabled ? new Log(LogLevel.Error)     : new Log?(); break; | ||||
|                 case LogLevel.Guest     : Guest     = enabled ? new Log(LogLevel.Guest)     : new Log?(); break; | ||||
|                 case LogLevel.AccessLog : AccessLog = enabled ? new Log(LogLevel.AccessLog) : new Log?(); break; | ||||
|                 case LogLevel.Stub      : Stub      = enabled ? new Log(LogLevel.Stub)      : new Log?(); break; | ||||
|                 case LogLevel.Trace     : Trace     = enabled ? new Log(LogLevel.Trace)     : new Log?(); break; | ||||
|                 case LogLevel.Notice    : break; | ||||
|                 default: throw new ArgumentException("Unknown Log Level", nameof(logLevel)); | ||||
| #pragma warning restore IDE0055 | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -2,9 +2,9 @@ using System; | ||||
| using System.Diagnostics.Contracts; | ||||
| using System.Runtime.InteropServices; | ||||
|  | ||||
| #pragma warning disable CS0169, IDE0051 // Remove unused private member | ||||
| namespace Ryujinx.Common.Memory | ||||
| { | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array1<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -15,7 +15,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array2<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -27,7 +26,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array3<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -39,7 +37,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array4<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -51,7 +48,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array5<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -63,7 +59,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array6<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -75,7 +70,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array7<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -87,7 +81,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array8<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -99,7 +92,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array9<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -111,7 +103,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array10<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -123,7 +114,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array11<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -135,7 +125,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array12<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -147,7 +136,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array13<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -159,7 +147,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array14<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -171,7 +158,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array15<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -183,7 +169,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array16<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -195,7 +180,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array17<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -207,7 +191,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array18<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -219,7 +202,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array19<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -231,7 +213,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array20<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -243,7 +224,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array21<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -255,7 +235,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array22<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -267,7 +246,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array23<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -279,7 +257,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array24<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -292,7 +269,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array25<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -305,7 +281,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array26<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -318,7 +293,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array27<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -331,7 +305,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array28<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -344,7 +317,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array29<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -357,7 +329,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array30<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -370,7 +341,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array31<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -383,7 +353,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array32<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -396,7 +365,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array33<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -409,7 +377,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array34<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -422,7 +389,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array35<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -435,7 +401,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array36<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -448,7 +413,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array37<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -461,7 +425,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array38<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -474,7 +437,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array39<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -487,7 +449,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array40<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -500,7 +461,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array41<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -513,7 +473,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array42<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -526,7 +485,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array43<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -539,7 +497,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array44<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -552,7 +509,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array45<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -565,7 +521,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array46<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -578,7 +533,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array47<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -591,7 +545,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array48<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -604,7 +557,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array49<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -617,7 +569,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array50<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -630,7 +581,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array51<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -643,7 +593,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array52<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -656,7 +605,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array53<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -669,7 +617,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array54<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -682,7 +629,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array55<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -695,7 +641,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array56<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -708,7 +653,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array57<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -721,7 +665,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array58<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -734,7 +677,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array59<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -747,7 +689,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array60<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -759,7 +700,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array61<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -771,7 +711,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array62<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -783,7 +722,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array63<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -795,7 +733,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array64<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -807,7 +744,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array65<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -819,7 +755,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array73<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -832,7 +767,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array96<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -845,7 +779,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array127<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -858,7 +791,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array128<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -871,7 +803,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array140<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -885,7 +816,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array256<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -898,7 +828,6 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
|  | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     public struct Array384<T> : IArray<T> where T : unmanaged | ||||
|     { | ||||
|         T _e0; | ||||
| @@ -915,4 +844,4 @@ namespace Ryujinx.Common.Memory | ||||
|         public Span<T> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, Length); | ||||
|     } | ||||
| } | ||||
|  | ||||
| #pragma warning restore CS0169, IDE0051 | ||||
|   | ||||
| @@ -94,7 +94,7 @@ namespace Ryujinx.Common.PreciseSleep | ||||
|             Bias = GetBias(0); | ||||
|         } | ||||
|  | ||||
|         [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|         [StructLayout(LayoutKind.Sequential)] | ||||
|         private struct Timespec | ||||
|         { | ||||
|             public long tv_sec;  // Seconds | ||||
|   | ||||
| @@ -1,5 +1,10 @@ | ||||
| using Ryujinx.Common.Utilities; | ||||
| using System; | ||||
| using System.Net.Http; | ||||
| using System.Net.Http.Json; | ||||
| using System.Reflection; | ||||
| using System.Text.Json.Serialization; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| namespace Ryujinx.Common | ||||
| { | ||||
| @@ -32,4 +37,6 @@ namespace Ryujinx.Common | ||||
|                 ? $"https://git.ryujinx.app/ryubing/ryujinx/-/compare/Canary-{currentVersion}...Canary-{newVersion}" | ||||
|                 : $"https://git.ryujinx.app/ryubing/ryujinx/-/releases/{newVersion}"; | ||||
|     } | ||||
|  | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -28,10 +28,12 @@ namespace Ryujinx.Common.SystemInterop | ||||
|         { | ||||
|             public int GdiplusVersion; | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|             public nint DebugEventCallback; | ||||
|             public int SuppressBackgroundThread; | ||||
|             public int SuppressExternalCodecs; | ||||
|             public int StartupParameters; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|             public static StartupInputEx Default => new() | ||||
|             { | ||||
|   | ||||
| @@ -12,7 +12,7 @@ namespace Ryujinx.Common.SystemInterop | ||||
|     [SupportedOSPlatform("windows")] | ||||
|     public partial class WindowsMultimediaTimerResolution : IDisposable | ||||
|     { | ||||
|         [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|         [StructLayout(LayoutKind.Sequential)] | ||||
|         public struct TimeCaps | ||||
|         { | ||||
|             public uint wPeriodMin; | ||||
|   | ||||
| @@ -9,8 +9,8 @@ namespace Ryujinx.Common.Utilities | ||||
|     [StructLayout(LayoutKind.Sequential, Size = 16)] | ||||
|     public struct Buffer16 | ||||
|     { | ||||
|         public ulong Low { get; set; } | ||||
|         public ulong High { get; set; } | ||||
|         [DebuggerBrowsable(DebuggerBrowsableState.Never)] private readonly ulong _dummy0; | ||||
|         [DebuggerBrowsable(DebuggerBrowsableState.Never)] private readonly ulong _dummy1; | ||||
|  | ||||
|         public byte this[int i] | ||||
|         { | ||||
|   | ||||
| @@ -241,7 +241,7 @@ namespace Ryujinx.Common.Utilities | ||||
|  | ||||
|             public IndentedStringBuilder Append(object value) | ||||
|             { | ||||
|                 Append(value.ToString()); | ||||
|                 this.Append(value.ToString()); | ||||
|  | ||||
|                 return this; | ||||
|             } | ||||
| @@ -271,7 +271,7 @@ namespace Ryujinx.Common.Utilities | ||||
|             { | ||||
|                 _builder.Append(value); | ||||
|  | ||||
|                 AppendLine(); | ||||
|                 this.AppendLine(); | ||||
|  | ||||
|                 return this; | ||||
|             } | ||||
|   | ||||
| @@ -32,6 +32,7 @@ namespace Ryujinx.Common.Utilities | ||||
|             CyclingEnabled = false; | ||||
|         } | ||||
|  | ||||
|  | ||||
|         public static float Speed { get; set; } = 1; | ||||
|  | ||||
|         private static readonly Lock _lock = new(); | ||||
|   | ||||
							
								
								
									
										17
									
								
								src/Ryujinx.Cpu/AppleHv/DummyDiskCacheLoadState.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/Ryujinx.Cpu/AppleHv/DummyDiskCacheLoadState.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| using System; | ||||
|  | ||||
| namespace Ryujinx.Cpu.AppleHv | ||||
| { | ||||
|     public class DummyDiskCacheLoadState : IDiskCacheLoadState | ||||
|     { | ||||
| #pragma warning disable CS0067 // The event is never used | ||||
|         /// <inheritdoc/> | ||||
|         public event Action<LoadState, int, int> StateChanged; | ||||
| #pragma warning restore CS0067 | ||||
|  | ||||
|         /// <inheritdoc/> | ||||
|         public void Cancel() | ||||
|         { | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -6,11 +6,11 @@ namespace Ryujinx.Cpu.AppleHv | ||||
| { | ||||
|     struct HvVcpuExitException | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public ulong Syndrome; | ||||
|         public ulong VirtualAddress; | ||||
|         public ulong PhysicalAddress; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     enum HvExitReason : uint | ||||
| @@ -23,10 +23,10 @@ namespace Ryujinx.Cpu.AppleHv | ||||
|  | ||||
|     struct HvVcpuExit | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public HvExitReason Reason; | ||||
|         public HvVcpuExitException Exception; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     enum HvReg : uint | ||||
|   | ||||
| @@ -4,10 +4,10 @@ namespace Ryujinx.Cpu | ||||
| { | ||||
|     public class DummyDiskCacheLoadState : IDiskCacheLoadState | ||||
|     { | ||||
| #pragma warning disable CS0067 // The event is never used | ||||
|         /// <inheritdoc/> | ||||
|         public event Action<LoadState, int, int> StateChanged; | ||||
|  | ||||
|         public DummyDiskCacheLoadState() => StateChanged?.Invoke(LoadState.Unloaded, 0, 0); | ||||
| #pragma warning restore CS0067 | ||||
|  | ||||
|         /// <inheritdoc/> | ||||
|         public void Cancel() | ||||
|   | ||||
| @@ -15,6 +15,7 @@ namespace Ryujinx.Cpu | ||||
|         /// <inheritdoc/> | ||||
|         public ulong Counter => (ulong)(ElapsedSeconds * Frequency); | ||||
|  | ||||
|  | ||||
|         public long TickScalar { get; set; } | ||||
|  | ||||
|         private static long _acumElapsedTicks; | ||||
|   | ||||
| @@ -143,7 +143,7 @@ namespace Ryujinx.Graphics.GAL | ||||
|  | ||||
|         public override bool Equals(object obj) | ||||
|         { | ||||
|             return obj is TextureCreateInfo info && Equals(info); | ||||
|             return obj is TextureCreateInfo info && this.Equals(info); | ||||
|         } | ||||
|  | ||||
|         public static bool operator ==(TextureCreateInfo left, TextureCreateInfo right) | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
|  | ||||
| namespace Ryujinx.Graphics.GAL | ||||
| { | ||||
|     public enum ViewportSwizzle | ||||
|   | ||||
| @@ -98,7 +98,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Compute | ||||
|     /// </summary> | ||||
|     unsafe struct ComputeClassState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint SetObject; | ||||
|         public readonly int SetObjectClassId => (int)(SetObject & 0xFFFF); | ||||
|         public readonly int SetObjectEngineId => (int)((SetObject >> 16) & 0x1F); | ||||
| @@ -430,6 +430,6 @@ namespace Ryujinx.Graphics.Gpu.Engine.Compute | ||||
|         public readonly int StopShaderPerformanceCounterCounterMask => (int)(StopShaderPerformanceCounter & 0xFF); | ||||
|         public fixed uint Reserved33E8[6]; | ||||
|         public Array256<uint> SetMmeShadowScratch; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -179,7 +179,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Dma | ||||
|     /// </summary> | ||||
|     unsafe struct DmaClassState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public fixed uint Reserved00[64]; | ||||
|         public uint Nop; | ||||
|         public fixed uint Reserved104[15]; | ||||
| @@ -266,6 +266,6 @@ namespace Ryujinx.Graphics.Gpu.Engine.Dma | ||||
|         public fixed uint Reserved740[629]; | ||||
|         public uint PmTriggerEnd; | ||||
|         public fixed uint Reserved1118[2490]; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -7,7 +7,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Dma | ||||
|     /// </summary> | ||||
|     struct DmaTexture | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public MemoryLayout MemoryLayout; | ||||
|         public int Width; | ||||
|         public int Height; | ||||
| @@ -15,6 +15,6 @@ namespace Ryujinx.Graphics.Gpu.Engine.Dma | ||||
|         public int RegionZ; | ||||
|         public ushort RegionX; | ||||
|         public ushort RegionY; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -25,9 +25,9 @@ namespace Ryujinx.Graphics.Gpu.Engine.GPFifo | ||||
|  | ||||
|     struct CompressedMethod | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Method; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|         public readonly int MethodAddressOld => (int)((Method >> 2) & 0x7FF); | ||||
|         public readonly int MethodAddress => (int)(Method & 0xFFF); | ||||
|         public readonly int SubdeviceMask => (int)((Method >> 4) & 0xFFF); | ||||
|   | ||||
| @@ -36,15 +36,15 @@ namespace Ryujinx.Graphics.Gpu.Engine.GPFifo | ||||
|  | ||||
|     struct GPEntry | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Entry0; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|         public readonly Entry0Fetch Entry0Fetch => (Entry0Fetch)(Entry0 & 0x1); | ||||
|         public readonly int Entry0Get => (int)((Entry0 >> 2) & 0x3FFFFFFF); | ||||
|         public readonly int Entry0Operand => (int)(Entry0); | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Entry1; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|         public readonly int Entry1GetHi => (int)(Entry1 & 0xFF); | ||||
|         public readonly Entry1Priv Entry1Priv => (Entry1Priv)((Entry1 >> 8) & 0x1); | ||||
|         public readonly Entry1Level Entry1Level => (Entry1Level)((Entry1 >> 9) & 0x1); | ||||
|   | ||||
| @@ -151,7 +151,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.GPFifo | ||||
|     /// </summary> | ||||
|     struct GPFifoClassState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint SetObject; | ||||
|         public readonly int SetObjectNvclass => (int)(SetObject & 0xFFFF); | ||||
|         public readonly int SetObjectEngine => (int)((SetObject >> 16) & 0x1F); | ||||
| @@ -228,6 +228,6 @@ namespace Ryujinx.Graphics.Gpu.Engine.GPFifo | ||||
|         public uint LoadMmeStartAddressRamPointer; | ||||
|         public uint LoadMmeStartAddressRam; | ||||
|         public uint SetMmeShadowRamControl; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -113,7 +113,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.InlineToMemory | ||||
|     /// </summary> | ||||
|     unsafe struct InlineToMemoryClassState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint SetObject; | ||||
|         public readonly int SetObjectClassId => (int)(SetObject & 0xFFFF); | ||||
|         public readonly int SetObjectEngineId => (int)((SetObject >> 16) & 0x1F); | ||||
| @@ -178,6 +178,6 @@ namespace Ryujinx.Graphics.Gpu.Engine.InlineToMemory | ||||
|         public uint SetI2mSpareNoop03; | ||||
|         public fixed uint Reserved200[3200]; | ||||
|         public Array256<uint> SetMmeShadowScratch; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -469,11 +469,12 @@ namespace Ryujinx.Graphics.Gpu.Engine.MME | ||||
|             for (int i = 0; i < maxDrawCount; i++) | ||||
|             { | ||||
|                 FifoWord count = FetchParam(); | ||||
|  | ||||
|                 _ = FetchParam(); // Instance count | ||||
| #pragma warning disable IDE0059 // Remove unnecessary value assignment | ||||
|                 FifoWord instanceCount = FetchParam(); | ||||
|                 FifoWord firstIndex = FetchParam(); | ||||
|                 _ = FetchParam(); // First vertex | ||||
|                 _ = FetchParam(); // First instance | ||||
|                 FifoWord firstVertex = FetchParam(); | ||||
|                 FifoWord firstInstance = FetchParam(); | ||||
| #pragma warning restore IDE0059 | ||||
|  | ||||
|                 if (i == 0) | ||||
|                 { | ||||
|   | ||||
| @@ -9,7 +9,9 @@ namespace Ryujinx.Graphics.Gpu.Engine | ||||
|     [StructLayout(LayoutKind.Sequential, Size = 1024)] | ||||
|     struct MmeShadowScratch | ||||
|     { | ||||
| #pragma warning disable CS0169 // The private field is never used | ||||
|         private uint _e0; | ||||
| #pragma warning restore CS0169 | ||||
|         public ref uint this[int index] => ref AsSpan()[index]; | ||||
|         public Span<uint> AsSpan() => MemoryMarshal.CreateSpan(ref _e0, 256); | ||||
|     } | ||||
|   | ||||
| @@ -16,8 +16,9 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         private int _inlineIndexBufferSize; | ||||
|         private int _inlineIndexCount; | ||||
|         private uint[] _buffer; | ||||
|  | ||||
| #pragma warning disable IDE0051 // Remove unused private member | ||||
|         private readonly int _bufferOffset; | ||||
| #pragma warning restore IDE0051 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Indicates if any index buffer data has been pushed. | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
|  | ||||
| namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
| { | ||||
|     /// <summary> | ||||
|   | ||||
| @@ -26,8 +26,9 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct TessMode | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Packed; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Unpacks the tessellation abstract patch type. | ||||
| @@ -62,7 +63,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct TfBufferState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 Enable; | ||||
|         public GpuVa Address; | ||||
|         public int Size; | ||||
| @@ -70,7 +71,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         public uint Padding0; | ||||
|         public uint Padding1; | ||||
|         public uint Padding2; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -78,12 +79,12 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct TfState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public int BufferIndex; | ||||
|         public int VaryingsCount; | ||||
|         public int Stride; | ||||
|         public uint Padding; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -91,7 +92,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct RtColorState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public GpuVa Address; | ||||
|         public int WidthOrStride; | ||||
|         public int Height; | ||||
| @@ -107,7 +108,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         public int Padding3; | ||||
|         public int Padding4; | ||||
|         public int Padding5; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -115,7 +116,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct ViewportTransform | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public float ScaleX; | ||||
|         public float ScaleY; | ||||
|         public float ScaleZ; | ||||
| @@ -124,6 +125,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         public float TranslateZ; | ||||
|         public uint Swizzle; | ||||
|         public uint SubpixelPrecisionBias; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Unpacks viewport swizzle of the position X component. | ||||
| @@ -167,14 +169,14 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct ViewportExtents | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public ushort X; | ||||
|         public ushort Width; | ||||
|         public ushort Y; | ||||
|         public ushort Height; | ||||
|         public float DepthNear; | ||||
|         public float DepthFar; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -182,10 +184,10 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct VertexBufferDrawState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public int First; | ||||
|         public int Count; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -193,12 +195,12 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct ClearColors | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public float Red; | ||||
|         public float Green; | ||||
|         public float Blue; | ||||
|         public float Alpha; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -206,11 +208,11 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct DepthBiasState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 PointEnable; | ||||
|         public Boolean32 LineEnable; | ||||
|         public Boolean32 FillEnable; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -229,14 +231,14 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct ScissorState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 Enable; | ||||
|         public ushort X1; | ||||
|         public ushort X2; | ||||
|         public ushort Y1; | ||||
|         public ushort Y2; | ||||
|         public uint Padding; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -244,11 +246,11 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct StencilBackMasks | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public int FuncRef; | ||||
|         public int Mask; | ||||
|         public int FuncMask; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -256,12 +258,12 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct RtDepthStencilState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public GpuVa Address; | ||||
|         public ZetaFormat Format; | ||||
|         public MemoryLayout MemoryLayout; | ||||
|         public int LayerSize; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -269,12 +271,12 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct ScreenScissorState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public ushort X; | ||||
|         public ushort Width; | ||||
|         public ushort Y; | ||||
|         public ushort Height; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -317,8 +319,9 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct VertexAttribState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Attribute; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Unpacks the index of the vertex buffer this attribute belongs to. | ||||
| @@ -380,8 +383,9 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct RtControl | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Packed; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Unpacks the number of active draw buffers. | ||||
| @@ -408,7 +412,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct Size3D | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public int Width; | ||||
|         public int Height; | ||||
|         public ushort Depth; | ||||
| @@ -418,6 +422,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         { | ||||
|             return (Flags & 1) == 0; | ||||
|         } | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -425,7 +430,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct StencilTestState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 Enable; | ||||
|         public StencilOp FrontSFail; | ||||
|         public StencilOp FrontDpFail; | ||||
| @@ -434,7 +439,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         public int FrontFuncRef; | ||||
|         public int FrontFuncMask; | ||||
|         public int FrontMask; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -452,11 +457,12 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct RgbHalf | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint R; | ||||
|         public uint G; | ||||
|         public uint B; | ||||
|         public uint Padding; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Unpacks the red color component as a 16-bit float value. | ||||
| @@ -506,10 +512,10 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct PoolState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public GpuVa Address; | ||||
|         public int MaximumId; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -517,13 +523,13 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct StencilBackTestState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 TwoSided; | ||||
|         public StencilOp BackSFail; | ||||
|         public StencilOp BackDpFail; | ||||
|         public StencilOp BackDpPass; | ||||
|         public CompareOp BackFunc; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -531,10 +537,10 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct PrimitiveRestartState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 Enable; | ||||
|         public int Index; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -543,12 +549,12 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct IndexBufferState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public GpuVa Address; | ||||
|         public GpuVa EndAddress; | ||||
|         public IndexType Type; | ||||
|         public int First; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -556,11 +562,11 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct FaceState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 CullEnable; | ||||
|         public FrontFace FrontFace; | ||||
|         public Face CullFace; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -578,10 +584,10 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct LogicalOpState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 Enable; | ||||
|         public LogicalOp LogicalOp; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -639,10 +645,11 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct VertexBufferState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Control; | ||||
|         public GpuVa Address; | ||||
|         public int Divisor; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Vertex buffer stride, defined as the number of bytes occupied by each vertex in memory. | ||||
| @@ -668,7 +675,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct BlendStateCommon | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 SeparateAlpha; | ||||
|         public BlendOp ColorOp; | ||||
|         public BlendFactor ColorSrcFactor; | ||||
| @@ -677,7 +684,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         public BlendFactor AlphaSrcFactor; | ||||
|         public uint Unknown0x1354; | ||||
|         public BlendFactor AlphaDstFactor; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -685,7 +692,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct BlendState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Boolean32 SeparateAlpha; | ||||
|         public BlendOp ColorOp; | ||||
|         public BlendFactor ColorSrcFactor; | ||||
| @@ -694,7 +701,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         public BlendFactor AlphaSrcFactor; | ||||
|         public BlendFactor AlphaDstFactor; | ||||
|         public uint Padding; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -702,7 +709,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct ShaderState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Control; | ||||
|         public uint Offset; | ||||
|         public uint Unknown0x8; | ||||
| @@ -719,6 +726,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         public uint Unknown0x34; | ||||
|         public uint Unknown0x38; | ||||
|         public uint Unknown0x3c; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Unpacks shader enable information. | ||||
| @@ -736,16 +744,16 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|     /// </summary> | ||||
|     struct UniformBufferState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public int Size; | ||||
|         public GpuVa Address; | ||||
|         public int Offset; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     unsafe struct ThreedClassState : IShadowState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint SetObject; | ||||
|         public readonly int SetObjectClassId => (int)(SetObject & 0xFFFF); | ||||
|         public readonly int SetObjectEngineId => (int)((SetObject >> 16) & 0x1F); | ||||
| @@ -1044,6 +1052,6 @@ namespace Ryujinx.Graphics.Gpu.Engine.Threed | ||||
|         public Array4<Array32<uint>> TfVaryingLocations; | ||||
|         public fixed uint Reserved2A00[640]; | ||||
|         public Array256<uint> SetMmeShadowScratch; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -486,10 +486,10 @@ namespace Ryujinx.Graphics.Gpu.Engine.Twod | ||||
|     /// </summary> | ||||
|     struct RenderSolidPrimPoint | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint SetX; | ||||
|         public uint Y; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
|  | ||||
|     /// <summary> | ||||
| @@ -497,7 +497,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Twod | ||||
|     /// </summary> | ||||
|     unsafe struct TwodClassState : IShadowState | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint SetObject; | ||||
|         public readonly int SetObjectClassId => (int)(SetObject & 0xFFFF); | ||||
|         public readonly int SetObjectEngineId => (int)((SetObject >> 16) & 0x1F); | ||||
| @@ -811,6 +811,6 @@ namespace Ryujinx.Graphics.Gpu.Engine.Twod | ||||
|         public readonly bool MmeDmaWriteMethodBarrierV => (MmeDmaWriteMethodBarrier & 0x1) != 0; | ||||
|         public fixed uint ReservedDF0[2436]; | ||||
|         public Array256<uint> SetMmeShadowScratch; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -7,7 +7,7 @@ namespace Ryujinx.Graphics.Gpu.Engine.Twod | ||||
|     /// </summary> | ||||
|     struct TwodTexture | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public ColorFormat Format; | ||||
|         public Boolean32 LinearLayout; | ||||
|         public MemoryLayout MemoryLayout; | ||||
| @@ -17,6 +17,6 @@ namespace Ryujinx.Graphics.Gpu.Engine.Twod | ||||
|         public int Width; | ||||
|         public int Height; | ||||
|         public GpuVa Address; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -5,9 +5,10 @@ namespace Ryujinx.Graphics.Gpu.Engine.Types | ||||
|     /// </summary> | ||||
|     struct GpuVa | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint High; | ||||
|         public uint Low; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Packs the split address into a 64-bits address value. | ||||
|   | ||||
| @@ -5,8 +5,9 @@ namespace Ryujinx.Graphics.Gpu.Engine.Types | ||||
|     /// </summary> | ||||
|     struct MemoryLayout | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Packed; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         public readonly int UnpackGobBlocksInX() | ||||
|         { | ||||
|   | ||||
| @@ -5,11 +5,12 @@ namespace Ryujinx.Graphics.Gpu.Engine.Types | ||||
|     /// </summary> | ||||
|     struct SbDescriptor | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint AddressLow; | ||||
|         public uint AddressHigh; | ||||
|         public int Size; | ||||
|         public int Padding; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         public readonly ulong PackAddress() | ||||
|         { | ||||
|   | ||||
| @@ -98,6 +98,7 @@ namespace Ryujinx.Graphics.Gpu | ||||
|         /// </summary> | ||||
|         internal DirtyHacks DirtyHacks { get; } | ||||
|  | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Host hardware capabilities. | ||||
|         /// </summary> | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| using Ryujinx.Graphics.GAL; | ||||
| using System.Collections.Generic; | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
|  | ||||
| namespace Ryujinx.Graphics.Gpu.Image | ||||
| { | ||||
| @@ -554,6 +555,7 @@ namespace Ryujinx.Graphics.Gpu.Image | ||||
|             { VertexAttributeFormat.A2B10G10R10Uscaled,  Format.R10G10B10A2Uscaled  }, | ||||
|             { VertexAttributeFormat.A2B10G10R10Sscaled,  Format.R10G10B10A2Sscaled  }, | ||||
|         }; | ||||
| #pragma warning restore IDE0055 | ||||
|  | ||||
|         // Note: Some of those formats have been changed and requires conversion on the shader, | ||||
|         // as GPUs don't support them when used as buffer texture format. | ||||
| @@ -638,7 +640,6 @@ namespace Ryujinx.Graphics.Gpu.Image | ||||
|             { VertexAttributeFormat.A2B10G10R10Sint,     (Format.R10G10B10A2Uint, 4)  }, // Sint -> Uint | ||||
|             { VertexAttributeFormat.A2B10G10R10Uscaled,  (Format.R10G10B10A2Uint, 4)  }, // Uscaled -> Uint | ||||
|             { VertexAttributeFormat.A2B10G10R10Sscaled,  (Format.R10G10B10A2Sint, 4)  }  // Sscaled -> Sint | ||||
| #pragma warning restore IDE0055 | ||||
|         }; | ||||
|  | ||||
|         /// <summary> | ||||
|   | ||||
| @@ -53,6 +53,7 @@ namespace Ryujinx.Graphics.Gpu.Image | ||||
|  | ||||
|         private const float Frac8ToF32 = 1.0f / 256.0f; | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Word0; | ||||
|         public uint Word1; | ||||
|         public uint Word2; | ||||
| @@ -61,6 +62,7 @@ namespace Ryujinx.Graphics.Gpu.Image | ||||
|         public float BorderColorG; | ||||
|         public float BorderColorB; | ||||
|         public float BorderColorA; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Unpacks the texture wrap mode along the X axis. | ||||
|   | ||||
| @@ -9,7 +9,7 @@ namespace Ryujinx.Graphics.Gpu.Image | ||||
|     /// </summary> | ||||
|     struct TextureDescriptor : ITextureDescriptor, IEquatable<TextureDescriptor> | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Word0; | ||||
|         public uint Word1; | ||||
|         public uint Word2; | ||||
| @@ -18,6 +18,7 @@ namespace Ryujinx.Graphics.Gpu.Image | ||||
|         public uint Word5; | ||||
|         public uint Word6; | ||||
|         public uint Word7; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Unpacks Maxwell texture format integer. | ||||
|   | ||||
| @@ -9,13 +9,14 @@ namespace Ryujinx.Graphics.Gpu.Shader | ||||
|     /// </summary> | ||||
|     struct ShaderAddresses : IEquatable<ShaderAddresses> | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public ulong VertexA; | ||||
|         public ulong VertexB; | ||||
|         public ulong TessControl; | ||||
|         public ulong TessEvaluation; | ||||
|         public ulong Geometry; | ||||
|         public ulong Fragment; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Check if the addresses are equal. | ||||
|   | ||||
| @@ -4,7 +4,7 @@ namespace Ryujinx.Graphics.Host1x | ||||
| { | ||||
|     struct Host1xClassRegisters | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint IncrSyncpt; | ||||
|         public uint IncrSyncptCntrl; | ||||
|         public uint IncrSyncptError; | ||||
| @@ -38,6 +38,6 @@ namespace Ryujinx.Graphics.Host1x | ||||
|         public uint Xrefctrl; | ||||
|         public uint ChannelXrefHi; | ||||
|         public uint ChannelXrefLo; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,7 @@ namespace Ryujinx.Graphics.Host1x | ||||
| { | ||||
|     struct ThiRegisters | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint IncrSyncpt; | ||||
|         public uint Reserved4; | ||||
|         public uint IncrSyncptErr; | ||||
| @@ -19,6 +19,6 @@ namespace Ryujinx.Graphics.Host1x | ||||
|         public Array12<uint> Reserved48; | ||||
|         public uint IntStatus; | ||||
|         public uint IntMask; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,7 +2,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
| { | ||||
|     struct AVCodec | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public unsafe byte* Name; | ||||
|         public unsafe byte* LongName; | ||||
|         public int Type; | ||||
| @@ -19,6 +19,6 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
|         public nint Profiles; | ||||
|         public unsafe byte* WrapperName; | ||||
|         public nint ChLayouts; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,7 +2,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
| { | ||||
|     struct AVCodec501 | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public unsafe byte* Name; | ||||
|         public unsafe byte* LongName; | ||||
|         public int Type; | ||||
| @@ -18,6 +18,6 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
|         public unsafe nint PrivClass; | ||||
|         public nint Profiles; | ||||
|         public unsafe byte* WrapperName; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
| { | ||||
|     struct AVCodecContext | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public unsafe nint AvClass; | ||||
|         public int LogLevelOffset; | ||||
|         public int CodecType; | ||||
| @@ -165,6 +165,6 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
|         public long MaxSamples; | ||||
|         public int ExportSideData; | ||||
|         public nint GetEncodeBuffer; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
| { | ||||
|     struct AVFrame | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Array8<nint> Data; | ||||
|         public Array8<int> LineSize; | ||||
|         public nint ExtendedData; | ||||
| @@ -29,6 +29,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
|         public long ReorderedOpaque; | ||||
|         public int SampleRate; | ||||
|         public ulong ChannelLayout; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         // NOTE: There is more after, but the layout kind of changed a bit and we don't need more than this. This is safe as we only manipulate this behind a reference. | ||||
|     } | ||||
|   | ||||
| @@ -4,7 +4,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
| { | ||||
|     struct AVPacket | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public unsafe AVBufferRef* Buf; | ||||
|         public long Pts; | ||||
|         public long Dts; | ||||
| @@ -19,6 +19,6 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
|         public AVBufferRef Opaque; | ||||
|         public unsafe AVBufferRef* OpaqueRef; | ||||
|         public AVRational TimeBase; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,7 +2,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
| { | ||||
|     struct FFCodec<T> where T : struct | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public T Base; | ||||
|         public int CapsInternalOrCbType; | ||||
|         public int PrivDataSize; | ||||
| @@ -12,6 +12,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
|         public nint InitStaticData; | ||||
|         public nint Init; | ||||
|         public nint CodecCallback; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         // NOTE: There is more after, but the layout kind of changed a bit and we don't need more than this. This is safe as we only manipulate this behind a reference. | ||||
|     } | ||||
|   | ||||
| @@ -2,7 +2,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
| { | ||||
|     struct FFCodecLegacy<T> where T : struct | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public T Base; | ||||
|         public uint CapsInternalOrCbType; | ||||
|         public int PrivDataSize; | ||||
| @@ -14,6 +14,7 @@ namespace Ryujinx.Graphics.Nvdec.FFmpeg.Native | ||||
|         public nint EncodeSub; | ||||
|         public nint Encode2; | ||||
|         public nint Decode; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         // NOTE: There is more after, but the layout kind of changed a bit and we don't need more than this. This is safe as we only manipulate this behind a reference. | ||||
|     } | ||||
|   | ||||
| @@ -6,10 +6,10 @@ namespace Ryujinx.Graphics.Nvdec.Vp9.Types | ||||
|     // passed it can be loaded into vector registers. | ||||
|     internal struct LoopFilterThresh | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Array16<byte> Mblim; | ||||
|         public Array16<byte> Lim; | ||||
|         public Array16<byte> HevThr; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,7 @@ namespace Ryujinx.Graphics.Nvdec | ||||
| { | ||||
|     struct NvdecRegisters | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Array64<uint> Reserved0; | ||||
|         public uint Nop; | ||||
|         public Array63<uint> Reserved104; | ||||
| @@ -58,6 +58,6 @@ namespace Ryujinx.Graphics.Nvdec | ||||
|         public uint Vp9SetColMvWriteBufOffset; | ||||
|         public uint Vp9SetColMvReadBufOffset; | ||||
|         public uint Vp9SetFilterBufferOffset; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -4,13 +4,13 @@ namespace Ryujinx.Graphics.Nvdec | ||||
| { | ||||
|     struct NvdecStatus | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint MbsCorrectlyDecoded; | ||||
|         public uint MbsInError; | ||||
|         public uint Reserved; | ||||
|         public uint ErrorStatus; | ||||
|         public FrameStats Stats; | ||||
|         public uint SliceHeaderErrorCode; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,14 +1,13 @@ | ||||
| using Ryujinx.Common.Memory; | ||||
| using Ryujinx.Graphics.Video; | ||||
| using System.Runtime.InteropServices; | ||||
|  | ||||
| namespace Ryujinx.Graphics.Nvdec.Types.H264 | ||||
| { | ||||
|     [StructLayout(LayoutKind.Sequential, Pack = 1)] | ||||
|     struct PictureInfo | ||||
|     { | ||||
| #pragma warning disable IDE0051, CS0169, CS0649 // Remove unused private member | ||||
|         Array18<uint> Unknown0; | ||||
|  | ||||
| #pragma warning restore IDE0051 | ||||
|         public uint BitstreamSize; | ||||
|         public uint NumSlices; | ||||
|         public uint Unknown50; | ||||
| @@ -50,6 +49,7 @@ namespace Ryujinx.Graphics.Nvdec.Types.H264 | ||||
|         public Array16<byte> MvcextViewRefMasksL1; | ||||
|         public uint Flags2; | ||||
|         public Array10<uint> Unknown2D4; | ||||
| #pragma warning restore CS0169, CS0649 | ||||
|  | ||||
|         public readonly bool MbAdaptiveFrameFieldFlag => (Flags & (1 << 0)) != 0; | ||||
|         public readonly bool Direct8x8InferenceFlag => (Flags & (1 << 1)) != 0; | ||||
|   | ||||
| @@ -4,10 +4,11 @@ namespace Ryujinx.Graphics.Nvdec.Types.H264 | ||||
| { | ||||
|     struct ReferenceFrame | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Flags; | ||||
|         public Array2<uint> FieldOrderCnt; | ||||
|         public uint FrameNum; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         public readonly uint OutputSurfaceIndex => (uint)Flags & 0x7f; | ||||
|     } | ||||
|   | ||||
| @@ -5,7 +5,7 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp8 | ||||
| { | ||||
|     struct PictureInfo | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Array13<uint> Unknown0; | ||||
|         public uint GpTimerTimeoutValue; | ||||
|         public ushort FrameWidth; | ||||
| @@ -58,6 +58,7 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp8 | ||||
|         public uint ResultValue; // ucode return result | ||||
|         public Array8<uint> PartitionOffset; | ||||
|         public Array3<uint> Reserved4; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         public Vp8PictureInfo Convert() | ||||
|         { | ||||
|   | ||||
| @@ -5,7 +5,7 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
| { | ||||
|     struct EntropyProbs | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Array10<Array10<Array8<byte>>> KfYModeProbE0ToE7; | ||||
|         public Array10<Array10<byte>> KfYModeProbE8; | ||||
|         public Array3<byte> Padding384; | ||||
| @@ -42,6 +42,7 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
|         public Array5<byte> CompRefProb; | ||||
|         public Array17<byte> Padding58F; | ||||
|         public Array4<Array2<Array2<Array6<Array6<Array4<byte>>>>>> CoefProbs; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         public void Convert(ref Vp9EntropyProbs fc) | ||||
|         { | ||||
|   | ||||
| @@ -2,11 +2,11 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
| { | ||||
|     struct FrameSize | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public ushort Width; | ||||
|         public ushort Height; | ||||
|         public ushort LumaPitch; | ||||
|         public ushort ChromaPitch; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,7 +2,7 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
| { | ||||
|     struct FrameStats | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public uint Unknown0; | ||||
|         public uint Unknown4; | ||||
|         public uint Pass2CycleCount; | ||||
| @@ -16,6 +16,6 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
|         public uint FrameStatusBwdMvyCnt; | ||||
|         public uint ErrorCtbPos; | ||||
|         public uint ErrorSlicePos; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -4,10 +4,10 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
| { | ||||
|     struct LoopFilter | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public byte ModeRefDeltaEnabled; | ||||
|         public Array4<sbyte> RefDeltas; | ||||
|         public Array2<sbyte> ModeDeltas; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -5,7 +5,7 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
| { | ||||
|     struct PictureInfo | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public Array12<uint> Unknown0; | ||||
|         public uint BitstreamSize; | ||||
|         public uint IsEncrypted; | ||||
| @@ -42,6 +42,7 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
|         public uint UnknownF4; | ||||
|         public uint UnknownF8; | ||||
|         public uint UnknownFC; | ||||
| #pragma warning restore CS0649 | ||||
|  | ||||
|         public readonly uint BitDepth => (SurfaceParams >> 1) & 0xf; | ||||
|  | ||||
|   | ||||
| @@ -4,13 +4,13 @@ namespace Ryujinx.Graphics.Nvdec.Types.Vp9 | ||||
| { | ||||
|     struct Segmentation | ||||
|     { | ||||
|  | ||||
| #pragma warning disable CS0649 // Field is never assigned to | ||||
|         public byte Enabled; | ||||
|         public byte UpdateMap; | ||||
|         public byte TemporalUpdate; | ||||
|         public byte AbsDelta; | ||||
|         public Array8<uint> FeatureMask; | ||||
|         public Array8<Array4<short>> FeatureData; | ||||
|  | ||||
| #pragma warning restore CS0649 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -16,7 +16,7 @@ namespace Ryujinx.Graphics.OpenGL | ||||
|             _table = new FormatInfo[tableSize]; | ||||
|             _tableImage = new SizedInternalFormat[tableSize]; | ||||
|  | ||||
|             #pragma warning disable IDE0055 // Disable formatting | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|             Add(Format.R8Unorm,             new FormatInfo(1, true,  false, All.R8,                PixelFormat.Red,            PixelType.UnsignedByte)); | ||||
|             Add(Format.R8Snorm,             new FormatInfo(1, true,  false, All.R8Snorm,           PixelFormat.Red,            PixelType.Byte)); | ||||
|             Add(Format.R8Uint,              new FormatInfo(1, false, false, All.R8ui,              PixelFormat.RedInteger,     PixelType.UnsignedByte)); | ||||
|   | ||||
| @@ -14,7 +14,7 @@ namespace Ryujinx.Graphics.Shader.CodeGen.Glsl.Instructions | ||||
|         { | ||||
|             _infoTable = new InstInfo[(int)Instruction.Count]; | ||||
|  | ||||
|             #pragma warning disable IDE0055 // Disable formatting | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|             Add(Instruction.AtomicAdd,                InstType.AtomicBinary,   "atomicAdd"); | ||||
|             Add(Instruction.AtomicAnd,                InstType.AtomicBinary,   "atomicAnd"); | ||||
|             Add(Instruction.AtomicCompareAndSwap,     InstType.AtomicTernary,  "atomicCompSwap"); | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| using System; | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
|  | ||||
| namespace Ryujinx.Graphics.Shader.CodeGen.Glsl.Instructions | ||||
| { | ||||
|   | ||||
| @@ -5,10 +5,11 @@ using Spv.Generator; | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using Instruction = Spv.Generator.Instruction; | ||||
| using IrOperandType = Ryujinx.Graphics.Shader.IntermediateRepresentation.OperandType; | ||||
|  | ||||
| namespace Ryujinx.Graphics.Shader.CodeGen.Spirv | ||||
| { | ||||
|     using IrOperandType = IntermediateRepresentation.OperandType; | ||||
|  | ||||
|     partial class CodeGenContext : Module | ||||
|     { | ||||
|         private const uint SpirvVersionMajor = 1; | ||||
|   | ||||
| @@ -6,11 +6,12 @@ using System.Collections.Generic; | ||||
| using System.Diagnostics; | ||||
| using System.Numerics; | ||||
| using static Spv.Specification; | ||||
| using SpvInstruction = Spv.Generator.Instruction; | ||||
| using SpvLiteralInteger = Spv.Generator.LiteralInteger; | ||||
|  | ||||
| namespace Ryujinx.Graphics.Shader.CodeGen.Spirv | ||||
| { | ||||
|     using SpvInstruction = Spv.Generator.Instruction; | ||||
|     using SpvLiteralInteger = Spv.Generator.LiteralInteger; | ||||
|  | ||||
|     static class Instructions | ||||
|     { | ||||
|         private const MemorySemanticsMask DefaultMemorySemantics = | ||||
| @@ -26,7 +27,7 @@ namespace Ryujinx.Graphics.Shader.CodeGen.Spirv | ||||
|         { | ||||
|             _instTable = new Func<CodeGenContext, AstOperation, OperationResult>[(int)Instruction.Count]; | ||||
|  | ||||
|             #pragma warning disable IDE0055 // Disable formatting | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|             Add(Instruction.Absolute,                 GenerateAbsolute); | ||||
|             Add(Instruction.Add,                      GenerateAdd); | ||||
|             Add(Instruction.AtomicAdd,                GenerateAtomicAdd); | ||||
|   | ||||
| @@ -6,13 +6,14 @@ using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Threading; | ||||
| using static Spv.Specification; | ||||
| using SpvInstruction = Spv.Generator.Instruction; | ||||
| using SpvInstructionPool = Spv.Generator.GeneratorPool<Spv.Generator.Instruction>; | ||||
| using SpvLiteralInteger = Spv.Generator.LiteralInteger; | ||||
| using SpvLiteralIntegerPool = Spv.Generator.GeneratorPool<Spv.Generator.LiteralInteger>; | ||||
|  | ||||
| namespace Ryujinx.Graphics.Shader.CodeGen.Spirv | ||||
| { | ||||
|     using SpvInstruction = Spv.Generator.Instruction; | ||||
|     using SpvInstructionPool = Spv.Generator.GeneratorPool<Spv.Generator.Instruction>; | ||||
|     using SpvLiteralInteger = Spv.Generator.LiteralInteger; | ||||
|     using SpvLiteralIntegerPool = Spv.Generator.GeneratorPool<Spv.Generator.LiteralInteger>; | ||||
|  | ||||
|     static class SpirvGenerator | ||||
|     { | ||||
|         // Resource pools for Spirv generation. Note: Increase count when more threads are being used. | ||||
|   | ||||
| @@ -3664,9 +3664,9 @@ namespace Ryujinx.Graphics.Shader.Decoders | ||||
|  | ||||
|     readonly struct InstLepc | ||||
|     { | ||||
|  | ||||
| #pragma warning disable IDE0052 // Remove unread private member | ||||
|         private readonly ulong _opcode; | ||||
|  | ||||
| #pragma warning restore IDE0052 | ||||
|         public InstLepc(ulong opcode) => _opcode = opcode; | ||||
|     } | ||||
|  | ||||
| @@ -4181,9 +4181,9 @@ namespace Ryujinx.Graphics.Shader.Decoders | ||||
|  | ||||
|     readonly struct InstRam | ||||
|     { | ||||
|  | ||||
| #pragma warning disable IDE0052 // Remove unread private member | ||||
|         private readonly ulong _opcode; | ||||
|  | ||||
| #pragma warning restore IDE0052 | ||||
|         public InstRam(ulong opcode) => _opcode = opcode; | ||||
|     } | ||||
|  | ||||
| @@ -4252,9 +4252,9 @@ namespace Ryujinx.Graphics.Shader.Decoders | ||||
|  | ||||
|     readonly struct InstRtt | ||||
|     { | ||||
|  | ||||
| #pragma warning disable IDE0052 // Remove unread private member | ||||
|         private readonly ulong _opcode; | ||||
|  | ||||
| #pragma warning restore IDE0052 | ||||
|         public InstRtt(ulong opcode) => _opcode = opcode; | ||||
|     } | ||||
|  | ||||
| @@ -4270,9 +4270,9 @@ namespace Ryujinx.Graphics.Shader.Decoders | ||||
|  | ||||
|     readonly struct InstSam | ||||
|     { | ||||
|  | ||||
| #pragma warning disable IDE0052 // Remove unread private member | ||||
|         private readonly ulong _opcode; | ||||
|  | ||||
| #pragma warning restore IDE0052 | ||||
|         public InstSam(ulong opcode) => _opcode = opcode; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -31,7 +31,7 @@ namespace Ryujinx.Graphics.Shader.Decoders | ||||
|             _opCodes = new TableEntry[1 << EncodingBits]; | ||||
|  | ||||
|             #region Instructions | ||||
|             #pragma warning disable IDE0055 // Disable formatting | ||||
| #pragma warning disable IDE0055 // Disable formatting | ||||
|             Add("1110111110100xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", InstName.Al2p,        InstEmit.Al2p,        InstProps.Rd  | InstProps.Ra); | ||||
|             Add("1110111111011xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", InstName.Ald,         InstEmit.Ald,         InstProps.Rd  | InstProps.Ra); | ||||
|             Add("1110111111110xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", InstName.Ast,         InstEmit.Ast,         InstProps.Ra  | InstProps.Rb2 | InstProps.Rc); | ||||
|   | ||||
| @@ -22,7 +22,9 @@ namespace Ryujinx.Graphics.Shader.Instructions | ||||
|  | ||||
|         public static void Depbar(EmitterContext context) | ||||
|         { | ||||
|             _ = context.GetOp<InstDepbar>(); | ||||
| #pragma warning disable IDE0059 // Remove unnecessary value assignment | ||||
|             InstDepbar op = context.GetOp<InstDepbar>(); | ||||
| #pragma warning restore IDE0059 | ||||
|  | ||||
|             // No operation. | ||||
|         } | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user