SwapByteOrderTest.cpp 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. //===- unittests/Support/SwapByteOrderTest.cpp - swap byte order test -----===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. #include "llvm/Support/SwapByteOrder.h"
  9. #include "gtest/gtest.h"
  10. #include <cstdlib>
  11. #include <ctime>
  12. using namespace llvm;
  13. #undef max
  14. namespace {
  15. // In these first two tests all of the original_uintx values are truncated
  16. // except for 64. We could avoid this, but there's really no point.
  17. TEST(getSwappedBytes, UnsignedRoundTrip) {
  18. // The point of the bit twiddling of magic is to test with and without bits
  19. // in every byte.
  20. uint64_t value = 1;
  21. for (std::size_t i = 0; i <= sizeof(value); ++i) {
  22. uint8_t original_uint8 = static_cast<uint8_t>(value);
  23. EXPECT_EQ(original_uint8,
  24. sys::getSwappedBytes(sys::getSwappedBytes(original_uint8)));
  25. uint16_t original_uint16 = static_cast<uint16_t>(value);
  26. EXPECT_EQ(original_uint16,
  27. sys::getSwappedBytes(sys::getSwappedBytes(original_uint16)));
  28. uint32_t original_uint32 = static_cast<uint32_t>(value);
  29. EXPECT_EQ(original_uint32,
  30. sys::getSwappedBytes(sys::getSwappedBytes(original_uint32)));
  31. uint64_t original_uint64 = static_cast<uint64_t>(value);
  32. EXPECT_EQ(original_uint64,
  33. sys::getSwappedBytes(sys::getSwappedBytes(original_uint64)));
  34. value = (value << 8) | 0x55; // binary 0101 0101.
  35. }
  36. }
  37. TEST(getSwappedBytes, SignedRoundTrip) {
  38. // The point of the bit twiddling of magic is to test with and without bits
  39. // in every byte.
  40. uint64_t value = 1;
  41. for (std::size_t i = 0; i <= sizeof(value); ++i) {
  42. int8_t original_int8 = static_cast<int8_t>(value);
  43. EXPECT_EQ(original_int8,
  44. sys::getSwappedBytes(sys::getSwappedBytes(original_int8)));
  45. int16_t original_int16 = static_cast<int16_t>(value);
  46. EXPECT_EQ(original_int16,
  47. sys::getSwappedBytes(sys::getSwappedBytes(original_int16)));
  48. int32_t original_int32 = static_cast<int32_t>(value);
  49. EXPECT_EQ(original_int32,
  50. sys::getSwappedBytes(sys::getSwappedBytes(original_int32)));
  51. int64_t original_int64 = static_cast<int64_t>(value);
  52. EXPECT_EQ(original_int64,
  53. sys::getSwappedBytes(sys::getSwappedBytes(original_int64)));
  54. // Test other sign.
  55. value *= -1;
  56. original_int8 = static_cast<int8_t>(value);
  57. EXPECT_EQ(original_int8,
  58. sys::getSwappedBytes(sys::getSwappedBytes(original_int8)));
  59. original_int16 = static_cast<int16_t>(value);
  60. EXPECT_EQ(original_int16,
  61. sys::getSwappedBytes(sys::getSwappedBytes(original_int16)));
  62. original_int32 = static_cast<int32_t>(value);
  63. EXPECT_EQ(original_int32,
  64. sys::getSwappedBytes(sys::getSwappedBytes(original_int32)));
  65. original_int64 = static_cast<int64_t>(value);
  66. EXPECT_EQ(original_int64,
  67. sys::getSwappedBytes(sys::getSwappedBytes(original_int64)));
  68. // Return to normal sign and twiddle.
  69. value *= -1;
  70. value = (value << 8) | 0x55; // binary 0101 0101.
  71. }
  72. }
  73. TEST(getSwappedBytes, uint8_t) {
  74. EXPECT_EQ(uint8_t(0x11), sys::getSwappedBytes(uint8_t(0x11)));
  75. }
  76. TEST(getSwappedBytes, uint16_t) {
  77. EXPECT_EQ(uint16_t(0x1122), sys::getSwappedBytes(uint16_t(0x2211)));
  78. }
  79. TEST(getSwappedBytes, uint32_t) {
  80. EXPECT_EQ(uint32_t(0x11223344), sys::getSwappedBytes(uint32_t(0x44332211)));
  81. }
  82. TEST(getSwappedBytes, uint64_t) {
  83. EXPECT_EQ(uint64_t(0x1122334455667788ULL),
  84. sys::getSwappedBytes(uint64_t(0x8877665544332211ULL)));
  85. }
  86. TEST(getSwappedBytes, int8_t) {
  87. EXPECT_EQ(int8_t(0x11), sys::getSwappedBytes(int8_t(0x11)));
  88. }
  89. TEST(getSwappedBytes, int16_t) {
  90. EXPECT_EQ(int16_t(0x1122), sys::getSwappedBytes(int16_t(0x2211)));
  91. }
  92. TEST(getSwappedBytes, int32_t) {
  93. EXPECT_EQ(int32_t(0x11223344), sys::getSwappedBytes(int32_t(0x44332211)));
  94. }
  95. TEST(getSwappedBytes, int64_t) {
  96. EXPECT_EQ(int64_t(0x1122334455667788LL),
  97. sys::getSwappedBytes(int64_t(0x8877665544332211LL)));
  98. }
  99. TEST(getSwappedBytes, float) {
  100. EXPECT_EQ(1.79366203433576585078237386661e-43f, sys::getSwappedBytes(-0.0f));
  101. // 0x11223344
  102. EXPECT_EQ(7.1653228759765625e2f, sys::getSwappedBytes(1.2795344e-28f));
  103. }
  104. TEST(getSwappedBytes, double) {
  105. EXPECT_EQ(6.32404026676795576546008054871e-322, sys::getSwappedBytes(-0.0));
  106. // 0x1122334455667788
  107. EXPECT_EQ(-7.08687663657301358331704585496e-268,
  108. sys::getSwappedBytes(3.84141202447173065923064450234e-226));
  109. }
  110. TEST(swapByteOrder, uint8_t) {
  111. uint8_t value = 0x11;
  112. sys::swapByteOrder(value);
  113. EXPECT_EQ(uint8_t(0x11), value);
  114. }
  115. TEST(swapByteOrder, uint16_t) {
  116. uint16_t value = 0x2211;
  117. sys::swapByteOrder(value);
  118. EXPECT_EQ(uint16_t(0x1122), value);
  119. }
  120. TEST(swapByteOrder, uint32_t) {
  121. uint32_t value = 0x44332211;
  122. sys::swapByteOrder(value);
  123. EXPECT_EQ(uint32_t(0x11223344), value);
  124. }
  125. TEST(swapByteOrder, uint64_t) {
  126. uint64_t value = 0x8877665544332211ULL;
  127. sys::swapByteOrder(value);
  128. EXPECT_EQ(uint64_t(0x1122334455667788ULL), value);
  129. }
  130. TEST(swapByteOrder, int8_t) {
  131. int8_t value = 0x11;
  132. sys::swapByteOrder(value);
  133. EXPECT_EQ(int8_t(0x11), value);
  134. }
  135. TEST(swapByteOrder, int16_t) {
  136. int16_t value = 0x2211;
  137. sys::swapByteOrder(value);
  138. EXPECT_EQ(int16_t(0x1122), value);
  139. }
  140. TEST(swapByteOrder, int32_t) {
  141. int32_t value = 0x44332211;
  142. sys::swapByteOrder(value);
  143. EXPECT_EQ(int32_t(0x11223344), value);
  144. }
  145. TEST(swapByteOrder, int64_t) {
  146. int64_t value = 0x8877665544332211LL;
  147. sys::swapByteOrder(value);
  148. EXPECT_EQ(int64_t(0x1122334455667788LL), value);
  149. }
  150. TEST(swapByteOrder, float) {
  151. float value = 7.1653228759765625e2f; // 0x44332211
  152. sys::swapByteOrder(value);
  153. EXPECT_EQ(1.2795344e-28f, value);
  154. }
  155. TEST(swapByteOrder, double) {
  156. double value = -7.08687663657301358331704585496e-268; // 0x8877665544332211
  157. sys::swapByteOrder(value);
  158. EXPECT_EQ(3.84141202447173065923064450234e-226, value);
  159. }
  160. }