diff options
| author | LDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com> | 2018-08-17 02:44:44 +0200 |
|---|---|---|
| committer | gdkchan <gab.dark.100@gmail.com> | 2018-08-16 21:44:44 -0300 |
| commit | 34100051e454d13dc94be75f01ff1188598eff00 (patch) | |
| tree | 046d859a99903a7a1166466a45c0674c07b03afc /Ryujinx.Tests/Cpu/Tester/Types | |
| parent | 521751795a1c97c0d97f6f8904a3be69b13d3a9d (diff) | |
Add SHA256H, SHA256H2, SHA256SU0, SHA256SU1 instructions; add 4 Tests (closed box). (#352)
* Update CpuTestSimd.cs
* Update CpuTestSimdReg.cs
* Update Pseudocode.cs
* Update Instructions.cs
* Update Bits.cs
* Update Integer.cs
* Update AOpCodeTable.cs
* Create AInstEmitSimdHash.cs
* Update ASoftFallback.cs
Diffstat (limited to 'Ryujinx.Tests/Cpu/Tester/Types')
| -rw-r--r-- | Ryujinx.Tests/Cpu/Tester/Types/Bits.cs | 67 | ||||
| -rw-r--r-- | Ryujinx.Tests/Cpu/Tester/Types/Integer.cs | 2 |
2 files changed, 19 insertions, 50 deletions
diff --git a/Ryujinx.Tests/Cpu/Tester/Types/Bits.cs b/Ryujinx.Tests/Cpu/Tester/Types/Bits.cs index 30d63264..87cdfcd2 100644 --- a/Ryujinx.Tests/Cpu/Tester/Types/Bits.cs +++ b/Ryujinx.Tests/Cpu/Tester/Types/Bits.cs @@ -14,14 +14,13 @@ namespace Ryujinx.Tests.Cpu.Tester.Types public Bits(bool[] values) => bits = new BitArray(values); public Bits(byte[] bytes) => bits = new BitArray(bytes); - public Bits(Bits bits) => this.bits = new BitArray(bits.bits); + public Bits(Bits bits) => this.bits = new BitArray(bits.bits); // Clone: deep copy. public Bits(int length) => bits = new BitArray(length); public Bits(int length, bool defaultValue) => bits = new BitArray(length, defaultValue); private Bits(BitArray bitArray) => bits = new BitArray(bitArray); public Bits(ulong value) => bits = new BitArray(BitConverter.GetBytes(value)); public Bits(uint value) => bits = new BitArray(BitConverter.GetBytes(value)); - public Bits(ushort value) => bits = new BitArray(BitConverter.GetBytes(value)); - public Bits(byte value) => bits = new BitArray(new byte[1] {value}); + public Bits(BigInteger value) => bits = new BitArray(value.ToByteArray()); private BitArray ToBitArray() => new BitArray(bits); public ulong ToUInt64() @@ -40,21 +39,21 @@ namespace Ryujinx.Tests.Cpu.Tester.Types return BitConverter.ToUInt32(dst, 0); } - public ushort ToUInt16() + public BigInteger ToBigInteger() { - byte[] dst = new byte[2]; + if (bits.Count != 64 && + bits.Count != 32 && + bits.Count != 16 && + bits.Count != 8) + { + throw new InvalidOperationException(); + } - bits.CopyTo(dst, 0); - - return BitConverter.ToUInt16(dst, 0); - } - public byte ToByte() - { - byte[] dst = new byte[1]; + byte[] dst = new byte[bits.Count / 8]; bits.CopyTo(dst, 0); - return dst[0]; + return new BigInteger(dst); } public bool this[int index] // ASL: "<>". @@ -101,7 +100,7 @@ namespace Ryujinx.Tests.Cpu.Tester.Types } public bool IsReadOnly { get => false; } // Mutable. - public int Count { get => bits.Count; } + public int Count { get => bits.Count; } // Not resizable. public bool IsSynchronized { get => bits.IsSynchronized; } public object SyncRoot { get => bits.SyncRoot; } public Bits And(Bits value) => new Bits(new BitArray(this.bits).And(value.bits)); // Immutable. @@ -180,17 +179,7 @@ namespace Ryujinx.Tests.Cpu.Tester.Types throw new ArgumentNullException(); } - BigInteger dst; - - switch (left.Count) - { - case 8: dst = left.ToByte() + right; break; - case 16: dst = left.ToUInt16() + right; break; - case 32: dst = left.ToUInt32() + right; break; - case 64: dst = left.ToUInt64() + right; break; - - default: throw new ArgumentOutOfRangeException(); - } + BigInteger dst = left.ToBigInteger() + right; return dst.SubBigInteger(left.Count - 1, 0); } @@ -203,20 +192,10 @@ namespace Ryujinx.Tests.Cpu.Tester.Types if (left.Count != right.Count) { - throw new ArgumentException(); + throw new InvalidOperationException(); } - BigInteger dst; - - switch (left.Count) - { - case 8: dst = left.ToByte() + (BigInteger)right.ToByte(); break; - case 16: dst = left.ToUInt16() + (BigInteger)right.ToUInt16(); break; - case 32: dst = left.ToUInt32() + (BigInteger)right.ToUInt32(); break; - case 64: dst = left.ToUInt64() + (BigInteger)right.ToUInt64(); break; - - default: throw new ArgumentOutOfRangeException(); - } + BigInteger dst = left.ToBigInteger() + right.ToBigInteger(); return dst.SubBigInteger(left.Count - 1, 0); } @@ -229,20 +208,10 @@ namespace Ryujinx.Tests.Cpu.Tester.Types if (left.Count != right.Count) { - throw new ArgumentException(); + throw new InvalidOperationException(); } - BigInteger dst; - - switch (left.Count) - { - case 8: dst = left.ToByte() - (BigInteger)right.ToByte(); break; - case 16: dst = left.ToUInt16() - (BigInteger)right.ToUInt16(); break; - case 32: dst = left.ToUInt32() - (BigInteger)right.ToUInt32(); break; - case 64: dst = left.ToUInt64() - (BigInteger)right.ToUInt64(); break; - - default: throw new ArgumentOutOfRangeException(); - } + BigInteger dst = left.ToBigInteger() - right.ToBigInteger(); return dst.SubBigInteger(left.Count - 1, 0); } diff --git a/Ryujinx.Tests/Cpu/Tester/Types/Integer.cs b/Ryujinx.Tests/Cpu/Tester/Types/Integer.cs index c72f3e25..49ba260c 100644 --- a/Ryujinx.Tests/Cpu/Tester/Types/Integer.cs +++ b/Ryujinx.Tests/Cpu/Tester/Types/Integer.cs @@ -14,7 +14,7 @@ namespace Ryujinx.Tests.Cpu.Tester.Types throw new IndexOutOfRangeException(); } - Bits src = new Bits(x.ToByteArray()); + Bits src = new Bits(x); bool[] dst = new bool[highIndex - lowIndex + 1]; for (int i = lowIndex, n = 0; i <= highIndex; i++, n++) |
