DivUtilsTest.cpp 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. // Copyright 2021 Dolphin Emulator Project
  2. // SPDX-License-Identifier: GPL-2.0-or-later
  3. #include <gtest/gtest.h>
  4. #include "Core/PowerPC/JitCommon/DivUtils.h"
  5. using namespace JitCommon;
  6. TEST(DivUtils, Signed)
  7. {
  8. SignedMagic m3 = SignedDivisionConstants(3);
  9. SignedMagic m5 = SignedDivisionConstants(5);
  10. SignedMagic m7 = SignedDivisionConstants(7);
  11. SignedMagic minus3 = SignedDivisionConstants(-3);
  12. SignedMagic minus5 = SignedDivisionConstants(-5);
  13. SignedMagic minus7 = SignedDivisionConstants(-7);
  14. EXPECT_EQ(0x55555556, m3.multiplier);
  15. EXPECT_EQ(0, m3.shift);
  16. EXPECT_EQ(0x66666667, m5.multiplier);
  17. EXPECT_EQ(1, m5.shift);
  18. EXPECT_EQ(-0x6DB6DB6D, m7.multiplier);
  19. EXPECT_EQ(2, m7.shift);
  20. EXPECT_EQ(-0x55555556, minus3.multiplier);
  21. EXPECT_EQ(0, minus3.shift);
  22. EXPECT_EQ(-0x66666667, minus5.multiplier);
  23. EXPECT_EQ(1, minus5.shift);
  24. EXPECT_EQ(0x6DB6DB6D, minus7.multiplier);
  25. EXPECT_EQ(2, minus7.shift);
  26. }
  27. TEST(DivUtils, Unsigned)
  28. {
  29. UnsignedMagic m3 = UnsignedDivisionConstants(3);
  30. UnsignedMagic m5 = UnsignedDivisionConstants(5);
  31. UnsignedMagic m7 = UnsignedDivisionConstants(7);
  32. UnsignedMagic m9 = UnsignedDivisionConstants(9);
  33. UnsignedMagic m19 = UnsignedDivisionConstants(19);
  34. EXPECT_EQ(0xAAAAAAABU, m3.multiplier);
  35. EXPECT_EQ(1, m3.shift);
  36. EXPECT_TRUE(m3.fast);
  37. EXPECT_EQ(0xCCCCCCCDU, m5.multiplier);
  38. EXPECT_EQ(2, m5.shift);
  39. EXPECT_TRUE(m5.fast);
  40. EXPECT_EQ(0x92492492U, m7.multiplier);
  41. EXPECT_EQ(2, m7.shift);
  42. EXPECT_FALSE(m7.fast);
  43. EXPECT_EQ(0x38E38E39U, m9.multiplier);
  44. EXPECT_EQ(1, m9.shift);
  45. EXPECT_TRUE(m9.fast);
  46. EXPECT_EQ(0xD79435E5U, m19.multiplier);
  47. EXPECT_EQ(4, m19.shift);
  48. EXPECT_FALSE(m19.fast);
  49. }