CpuTestBfm.cs 5.3 KB

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