CpuTestSimdArithmetic.cs 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. using ChocolArm64.State;
  2. using NUnit.Framework;
  3. namespace Ryujinx.Tests.Cpu
  4. {
  5. public class CpuTestSimdArithmetic : CpuTest
  6. {
  7. [TestCase(0x3FE66666u, 'N', false, 0x40000000u)]
  8. [TestCase(0x3F99999Au, 'N', false, 0x3F800000u)]
  9. [TestCase(0x404CCCCDu, 'P', false, 0x40800000u)]
  10. [TestCase(0x40733333u, 'P', false, 0x40800000u)]
  11. [TestCase(0x404CCCCDu, 'M', false, 0x40400000u)]
  12. [TestCase(0x40733333u, 'M', false, 0x40400000u)]
  13. [TestCase(0x3F99999Au, 'Z', false, 0x3F800000u)]
  14. [TestCase(0x3FE66666u, 'Z', false, 0x3F800000u)]
  15. [TestCase(0x00000000u, 'N', false, 0x00000000u)]
  16. [TestCase(0x00000000u, 'P', false, 0x00000000u)]
  17. [TestCase(0x00000000u, 'M', false, 0x00000000u)]
  18. [TestCase(0x00000000u, 'Z', false, 0x00000000u)]
  19. [TestCase(0x80000000u, 'N', false, 0x80000000u)]
  20. [TestCase(0x80000000u, 'P', false, 0x80000000u)]
  21. [TestCase(0x80000000u, 'M', false, 0x80000000u)]
  22. [TestCase(0x80000000u, 'Z', false, 0x80000000u)]
  23. [TestCase(0x7F800000u, 'N', false, 0x7F800000u)]
  24. [TestCase(0x7F800000u, 'P', false, 0x7F800000u)]
  25. [TestCase(0x7F800000u, 'M', false, 0x7F800000u)]
  26. [TestCase(0x7F800000u, 'Z', false, 0x7F800000u)]
  27. [TestCase(0xFF800000u, 'N', false, 0xFF800000u)]
  28. [TestCase(0xFF800000u, 'P', false, 0xFF800000u)]
  29. [TestCase(0xFF800000u, 'M', false, 0xFF800000u)]
  30. [TestCase(0xFF800000u, 'Z', false, 0xFF800000u)]
  31. [TestCase(0xFF800001u, 'N', false, 0xFFC00001u)]
  32. [TestCase(0xFF800001u, 'P', false, 0xFFC00001u)]
  33. [TestCase(0xFF800001u, 'M', false, 0xFFC00001u)]
  34. [TestCase(0xFF800001u, 'Z', false, 0xFFC00001u)]
  35. [TestCase(0xFF800001u, 'N', true, 0x7FC00000u)]
  36. [TestCase(0xFF800001u, 'P', true, 0x7FC00000u)]
  37. [TestCase(0xFF800001u, 'M', true, 0x7FC00000u)]
  38. [TestCase(0xFF800001u, 'Z', true, 0x7FC00000u)]
  39. [TestCase(0x7FC00002u, 'N', false, 0x7FC00002u)]
  40. [TestCase(0x7FC00002u, 'P', false, 0x7FC00002u)]
  41. [TestCase(0x7FC00002u, 'M', false, 0x7FC00002u)]
  42. [TestCase(0x7FC00002u, 'Z', false, 0x7FC00002u)]
  43. [TestCase(0x7FC00002u, 'N', true, 0x7FC00000u)]
  44. [TestCase(0x7FC00002u, 'P', true, 0x7FC00000u)]
  45. [TestCase(0x7FC00002u, 'M', true, 0x7FC00000u)]
  46. [TestCase(0x7FC00002u, 'Z', true, 0x7FC00000u)]
  47. public void Frintx_S(uint A, char RoundType, bool DefaultNaN, uint Result)
  48. {
  49. int FpcrTemp = 0x0;
  50. switch(RoundType)
  51. {
  52. case 'N':
  53. FpcrTemp = 0x0;
  54. break;
  55. case 'P':
  56. FpcrTemp = 0x400000;
  57. break;
  58. case 'M':
  59. FpcrTemp = 0x800000;
  60. break;
  61. case 'Z':
  62. FpcrTemp = 0xC00000;
  63. break;
  64. }
  65. if(DefaultNaN)
  66. {
  67. FpcrTemp |= 1 << 25;
  68. }
  69. AVec V1 = new AVec { X0 = A };
  70. AThreadState ThreadState = SingleOpcode(0x1E274020, V1: V1, Fpcr: FpcrTemp);
  71. Assert.AreEqual(Result, ThreadState.V0.X0);
  72. }
  73. }
  74. }