CpuTestScalar.cs 1.2 KB

123456789101112131415161718192021222324252627282930
  1. using ChocolArm64.State;
  2. using NUnit.Framework;
  3. namespace Ryujinx.Tests.Cpu
  4. {
  5. [TestFixture]
  6. public partial class CpuTest
  7. {
  8. [TestCase(0x00000000u, 0x80000000u, 0x00000000u)]
  9. [TestCase(0x80000000u, 0x00000000u, 0x00000000u)]
  10. [TestCase(0x80000000u, 0x80000000u, 0x80000000u)]
  11. [TestCase(0x3DCCCCCDu, 0x3C9623B1u, 0x3DCCCCCDu)]
  12. [TestCase(0x8BA98D27u, 0x00000076u, 0x00000076u)]
  13. [TestCase(0x807FFFFFu, 0x7F7FFFFFu, 0x7F7FFFFFu)]
  14. [TestCase(0x7F7FFFFFu, 0x807FFFFFu, 0x7F7FFFFFu)]
  15. [TestCase(0x7FC00000u, 0x3F800000u, 0x7FC00000u)]
  16. [TestCase(0x3F800000u, 0x7FC00000u, 0x7FC00000u)]
  17. // NaN tests
  18. //[TestCase(0x7F800001u, 0x7FC00042u, 0x7FC00001u)]
  19. //[TestCase(0x7FC00042u, 0x7F800001u, 0x7FC00001u)]
  20. //[TestCase(0x7FC0000Au, 0x7FC0000Bu, 0x7FC0000Au)]
  21. public void Fmax_S(uint A, uint B, uint Result)
  22. {
  23. // FMAX S0, S1, S2
  24. uint Opcode = 0x1E224820;
  25. AThreadState ThreadState = SingleOpcode(Opcode, V1: new AVec { W0 = A }, V2: new AVec { W0 = B });
  26. Assert.AreEqual(Result, ThreadState.V0.W0);
  27. }
  28. }
  29. }