CpuTestBfm.cs 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. #define Bfm
  2. using NUnit.Framework;
  3. namespace Ryujinx.Tests.Cpu
  4. {
  5. [Category("Bfm")]
  6. public sealed class CpuTestBfm : CpuTest
  7. {
  8. #if Bfm
  9. private const int RndCnt = 2;
  10. private const int RndCntImmr = 2;
  11. private const int RndCntImms = 2;
  12. [Test, Pairwise, Description("BFM <Xd>, <Xn>, #<immr>, #<imms>")]
  13. public void Bfm_64bit([Values(0u, 31u)] uint rd,
  14. [Values(1u, 31u)] uint rn,
  15. [Random(RndCnt)] ulong xd,
  16. [Values(0x0000000000000000ul, 0x7FFFFFFFFFFFFFFFul,
  17. 0x8000000000000000ul, 0xFFFFFFFFFFFFFFFFul)] [Random(RndCnt)] ulong xn,
  18. [Values(0u, 31u, 32u, 63u)] [Random(0u, 63u, RndCntImmr)] uint immr,
  19. [Values(0u, 31u, 32u, 63u)] [Random(0u, 63u, RndCntImms)] uint imms)
  20. {
  21. uint opcode = 0xB3400000; // BFM X0, X0, #0, #0
  22. opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
  23. opcode |= ((immr & 63) << 16) | ((imms & 63) << 10);
  24. ulong x31 = TestContext.CurrentContext.Random.NextULong();
  25. SingleOpcode(opcode, x0: xd, x1: xn, x31: x31);
  26. CompareAgainstUnicorn();
  27. }
  28. [Test, Pairwise, Description("BFM <Wd>, <Wn>, #<immr>, #<imms>")]
  29. public void Bfm_32bit([Values(0u, 31u)] uint rd,
  30. [Values(1u, 31u)] uint rn,
  31. [Random(RndCnt)] uint wd,
  32. [Values(0x00000000u, 0x7FFFFFFFu,
  33. 0x80000000u, 0xFFFFFFFFu)] [Random(RndCnt)] uint wn,
  34. [Values(0u, 15u, 16u, 31u)] [Random(0u, 31u, RndCntImmr)] uint immr,
  35. [Values(0u, 15u, 16u, 31u)] [Random(0u, 31u, RndCntImms)] uint imms)
  36. {
  37. uint opcode = 0x33000000; // BFM W0, W0, #0, #0
  38. opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
  39. opcode |= ((immr & 63) << 16) | ((imms & 63) << 10);
  40. uint w31 = TestContext.CurrentContext.Random.NextUInt();
  41. SingleOpcode(opcode, x0: wd, x1: wn, x31: w31);
  42. CompareAgainstUnicorn();
  43. }
  44. [Test, Pairwise, Description("SBFM <Xd>, <Xn>, #<immr>, #<imms>")]
  45. public void Sbfm_64bit([Values(0u, 31u)] uint rd,
  46. [Values(1u, 31u)] uint rn,
  47. [Values(0x0000000000000000ul, 0x7FFFFFFFFFFFFFFFul,
  48. 0x8000000000000000ul, 0xFFFFFFFFFFFFFFFFul)] [Random(RndCnt)] ulong xn,
  49. [Values(0u, 31u, 32u, 63u)] [Random(0u, 63u, RndCntImmr)] uint immr,
  50. [Values(0u, 31u, 32u, 63u)] [Random(0u, 63u, RndCntImms)] uint imms)
  51. {
  52. uint opcode = 0x93400000; // SBFM X0, X0, #0, #0
  53. opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
  54. opcode |= ((immr & 63) << 16) | ((imms & 63) << 10);
  55. ulong x31 = TestContext.CurrentContext.Random.NextULong();
  56. SingleOpcode(opcode, x1: xn, x31: x31);
  57. CompareAgainstUnicorn();
  58. }
  59. [Test, Pairwise, Description("SBFM <Wd>, <Wn>, #<immr>, #<imms>")]
  60. public void Sbfm_32bit([Values(0u, 31u)] uint rd,
  61. [Values(1u, 31u)] uint rn,
  62. [Values(0x00000000u, 0x7FFFFFFFu,
  63. 0x80000000u, 0xFFFFFFFFu)] [Random(RndCnt)] uint wn,
  64. [Values(0u, 15u, 16u, 31u)] [Random(0u, 31u, RndCntImmr)] uint immr,
  65. [Values(0u, 15u, 16u, 31u)] [Random(0u, 31u, RndCntImms)] uint imms)
  66. {
  67. uint opcode = 0x13000000; // SBFM W0, W0, #0, #0
  68. opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
  69. opcode |= ((immr & 63) << 16) | ((imms & 63) << 10);
  70. uint w31 = TestContext.CurrentContext.Random.NextUInt();
  71. SingleOpcode(opcode, x1: wn, x31: w31);
  72. CompareAgainstUnicorn();
  73. }
  74. [Test, Pairwise, Description("UBFM <Xd>, <Xn>, #<immr>, #<imms>")]
  75. public void Ubfm_64bit([Values(0u, 31u)] uint rd,
  76. [Values(1u, 31u)] uint rn,
  77. [Values(0x0000000000000000ul, 0x7FFFFFFFFFFFFFFFul,
  78. 0x8000000000000000ul, 0xFFFFFFFFFFFFFFFFul)] [Random(RndCnt)] ulong xn,
  79. [Values(0u, 31u, 32u, 63u)] [Random(0u, 63u, RndCntImmr)] uint immr,
  80. [Values(0u, 31u, 32u, 63u)] [Random(0u, 63u, RndCntImms)] uint imms)
  81. {
  82. uint opcode = 0xD3400000; // UBFM X0, X0, #0, #0
  83. opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
  84. opcode |= ((immr & 63) << 16) | ((imms & 63) << 10);
  85. ulong x31 = TestContext.CurrentContext.Random.NextULong();
  86. SingleOpcode(opcode, x1: xn, x31: x31);
  87. CompareAgainstUnicorn();
  88. }
  89. [Test, Pairwise, Description("UBFM <Wd>, <Wn>, #<immr>, #<imms>")]
  90. public void Ubfm_32bit([Values(0u, 31u)] uint rd,
  91. [Values(1u, 31u)] uint rn,
  92. [Values(0x00000000u, 0x7FFFFFFFu,
  93. 0x80000000u, 0xFFFFFFFFu)] [Random(RndCnt)] uint wn,
  94. [Values(0u, 15u, 16u, 31u)] [Random(0u, 31u, RndCntImmr)] uint immr,
  95. [Values(0u, 15u, 16u, 31u)] [Random(0u, 31u, RndCntImms)] uint imms)
  96. {
  97. uint opcode = 0x53000000; // UBFM W0, W0, #0, #0
  98. opcode |= ((rn & 31) << 5) | ((rd & 31) << 0);
  99. opcode |= ((immr & 63) << 16) | ((imms & 63) << 10);
  100. uint w31 = TestContext.CurrentContext.Random.NextUInt();
  101. SingleOpcode(opcode, x1: wn, x31: w31);
  102. CompareAgainstUnicorn();
  103. }
  104. #endif
  105. }
  106. }