CpuTestSimdCvt.cs 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. using ChocolArm64.State;
  2. using NUnit.Framework;
  3. using System.Runtime.Intrinsics;
  4. using System.Runtime.Intrinsics.X86;
  5. namespace Ryujinx.Tests.Cpu
  6. {
  7. public class CpuTestSimdCvt : CpuTest
  8. {
  9. [TestCase((ushort)0x0000, 0x00000000u)] // Positive Zero
  10. [TestCase((ushort)0x8000, 0x80000000u)] // Negative Zero
  11. [TestCase((ushort)0x3E00, 0x3FC00000u)] // +1.5
  12. [TestCase((ushort)0xBE00, 0xBFC00000u)] // -1.5
  13. [TestCase((ushort)0xFFFF, 0xFFFFE000u)] // -QNaN
  14. [TestCase((ushort)0x7C00, 0x7F800000u)] // +Inf
  15. [TestCase((ushort)0x3C00, 0x3F800000u)] // 1.0
  16. [TestCase((ushort)0x3C01, 0x3F802000u)] // 1.0009765625
  17. [TestCase((ushort)0xC000, 0xC0000000u)] // -2.0
  18. [TestCase((ushort)0x7BFF, 0x477FE000u)] // 65504.0 (Largest Normal)
  19. [TestCase((ushort)0x03FF, 0x387FC000u)] // 0.00006097555 (Largest Subnormal)
  20. [TestCase((ushort)0x0001, 0x33800000u)] // 5.96046448e-8 (Smallest Subnormal)
  21. public void Fcvtl_V_f16(ushort Value, uint Result)
  22. {
  23. uint Opcode = 0x0E217801;
  24. Vector128<float> V0 = Sse.StaticCast<ushort, float>(Sse2.SetAllVector128(Value));
  25. AThreadState ThreadState = SingleOpcode(Opcode, V0: V0);
  26. Assert.Multiple(() =>
  27. {
  28. Assert.That(Sse41.Extract(Sse.StaticCast<float, uint>(ThreadState.V1), (byte)0), Is.EqualTo(Result));
  29. Assert.That(Sse41.Extract(Sse.StaticCast<float, uint>(ThreadState.V1), (byte)1), Is.EqualTo(Result));
  30. Assert.That(Sse41.Extract(Sse.StaticCast<float, uint>(ThreadState.V1), (byte)2), Is.EqualTo(Result));
  31. Assert.That(Sse41.Extract(Sse.StaticCast<float, uint>(ThreadState.V1), (byte)3), Is.EqualTo(Result));
  32. });
  33. }
  34. }
  35. }