1ded95b79SMichael J. Spencer //===- unittests/Support/SwapByteOrderTest.cpp - swap byte order test -----===//
2ded95b79SMichael J. Spencer //
32946cd70SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
42946cd70SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
52946cd70SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6ded95b79SMichael J. Spencer //
7ded95b79SMichael J. Spencer //===----------------------------------------------------------------------===//
8ded95b79SMichael J. Spencer
9447762daSMichael J. Spencer #include "llvm/Support/SwapByteOrder.h"
109a67b073SChandler Carruth #include "gtest/gtest.h"
11ded95b79SMichael J. Spencer #include <cstdlib>
12ded95b79SMichael J. Spencer #include <ctime>
13ded95b79SMichael J. Spencer using namespace llvm;
14ded95b79SMichael J. Spencer
15ded95b79SMichael J. Spencer #undef max
16ded95b79SMichael J. Spencer
17ded95b79SMichael J. Spencer namespace {
18ded95b79SMichael J. Spencer
TEST(ByteSwap,Swap_32)19*e3a9b0f3SReid Kleckner TEST(ByteSwap, Swap_32) {
20*e3a9b0f3SReid Kleckner EXPECT_EQ(0x44332211u, ByteSwap_32(0x11223344));
21*e3a9b0f3SReid Kleckner EXPECT_EQ(0xDDCCBBAAu, ByteSwap_32(0xAABBCCDD));
22*e3a9b0f3SReid Kleckner }
23*e3a9b0f3SReid Kleckner
TEST(ByteSwap,Swap_64)24*e3a9b0f3SReid Kleckner TEST(ByteSwap, Swap_64) {
25*e3a9b0f3SReid Kleckner EXPECT_EQ(0x8877665544332211ULL, ByteSwap_64(0x1122334455667788LL));
26*e3a9b0f3SReid Kleckner EXPECT_EQ(0x1100FFEEDDCCBBAAULL, ByteSwap_64(0xAABBCCDDEEFF0011LL));
27*e3a9b0f3SReid Kleckner }
28*e3a9b0f3SReid Kleckner
29cb402911SAlp Toker // In these first two tests all of the original_uintx values are truncated
30ded95b79SMichael J. Spencer // except for 64. We could avoid this, but there's really no point.
31ded95b79SMichael J. Spencer
TEST(getSwappedBytes,UnsignedRoundTrip)32ef5e867fSArtyom Skrobov TEST(getSwappedBytes, UnsignedRoundTrip) {
33ded95b79SMichael J. Spencer // The point of the bit twiddling of magic is to test with and without bits
34ded95b79SMichael J. Spencer // in every byte.
35ded95b79SMichael J. Spencer uint64_t value = 1;
36ded95b79SMichael J. Spencer for (std::size_t i = 0; i <= sizeof(value); ++i) {
37cb402911SAlp Toker uint8_t original_uint8 = static_cast<uint8_t>(value);
38cb402911SAlp Toker EXPECT_EQ(original_uint8,
39ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_uint8)));
40ded95b79SMichael J. Spencer
41cb402911SAlp Toker uint16_t original_uint16 = static_cast<uint16_t>(value);
42cb402911SAlp Toker EXPECT_EQ(original_uint16,
43ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_uint16)));
44ded95b79SMichael J. Spencer
45cb402911SAlp Toker uint32_t original_uint32 = static_cast<uint32_t>(value);
46cb402911SAlp Toker EXPECT_EQ(original_uint32,
47ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_uint32)));
48ded95b79SMichael J. Spencer
49cb402911SAlp Toker uint64_t original_uint64 = static_cast<uint64_t>(value);
50cb402911SAlp Toker EXPECT_EQ(original_uint64,
51ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_uint64)));
52ded95b79SMichael J. Spencer
53ded95b79SMichael J. Spencer value = (value << 8) | 0x55; // binary 0101 0101.
54ded95b79SMichael J. Spencer }
55ded95b79SMichael J. Spencer }
56ded95b79SMichael J. Spencer
TEST(getSwappedBytes,SignedRoundTrip)57ef5e867fSArtyom Skrobov TEST(getSwappedBytes, SignedRoundTrip) {
58ded95b79SMichael J. Spencer // The point of the bit twiddling of magic is to test with and without bits
59ded95b79SMichael J. Spencer // in every byte.
60ded95b79SMichael J. Spencer uint64_t value = 1;
61ded95b79SMichael J. Spencer for (std::size_t i = 0; i <= sizeof(value); ++i) {
62cb402911SAlp Toker int8_t original_int8 = static_cast<int8_t>(value);
63cb402911SAlp Toker EXPECT_EQ(original_int8,
64ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_int8)));
65ded95b79SMichael J. Spencer
66cb402911SAlp Toker int16_t original_int16 = static_cast<int16_t>(value);
67cb402911SAlp Toker EXPECT_EQ(original_int16,
68ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_int16)));
69ded95b79SMichael J. Spencer
70cb402911SAlp Toker int32_t original_int32 = static_cast<int32_t>(value);
71cb402911SAlp Toker EXPECT_EQ(original_int32,
72ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_int32)));
73ded95b79SMichael J. Spencer
74cb402911SAlp Toker int64_t original_int64 = static_cast<int64_t>(value);
75cb402911SAlp Toker EXPECT_EQ(original_int64,
76ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_int64)));
77ded95b79SMichael J. Spencer
78ded95b79SMichael J. Spencer // Test other sign.
79ded95b79SMichael J. Spencer value *= -1;
80ded95b79SMichael J. Spencer
81cb402911SAlp Toker original_int8 = static_cast<int8_t>(value);
82cb402911SAlp Toker EXPECT_EQ(original_int8,
83ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_int8)));
84ded95b79SMichael J. Spencer
85cb402911SAlp Toker original_int16 = static_cast<int16_t>(value);
86cb402911SAlp Toker EXPECT_EQ(original_int16,
87ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_int16)));
88ded95b79SMichael J. Spencer
89cb402911SAlp Toker original_int32 = static_cast<int32_t>(value);
90cb402911SAlp Toker EXPECT_EQ(original_int32,
91ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_int32)));
92ded95b79SMichael J. Spencer
93cb402911SAlp Toker original_int64 = static_cast<int64_t>(value);
94cb402911SAlp Toker EXPECT_EQ(original_int64,
95ef5e867fSArtyom Skrobov sys::getSwappedBytes(sys::getSwappedBytes(original_int64)));
96ded95b79SMichael J. Spencer
97ded95b79SMichael J. Spencer // Return to normal sign and twiddle.
98ded95b79SMichael J. Spencer value *= -1;
99ded95b79SMichael J. Spencer value = (value << 8) | 0x55; // binary 0101 0101.
100ded95b79SMichael J. Spencer }
101ded95b79SMichael J. Spencer }
102ded95b79SMichael J. Spencer
TEST(getSwappedBytes,uint8_t)103ef5e867fSArtyom Skrobov TEST(getSwappedBytes, uint8_t) {
104ef5e867fSArtyom Skrobov EXPECT_EQ(uint8_t(0x11), sys::getSwappedBytes(uint8_t(0x11)));
105ded95b79SMichael J. Spencer }
106ded95b79SMichael J. Spencer
TEST(getSwappedBytes,uint16_t)107ef5e867fSArtyom Skrobov TEST(getSwappedBytes, uint16_t) {
108ef5e867fSArtyom Skrobov EXPECT_EQ(uint16_t(0x1122), sys::getSwappedBytes(uint16_t(0x2211)));
109ded95b79SMichael J. Spencer }
110ded95b79SMichael J. Spencer
TEST(getSwappedBytes,uint32_t)111ef5e867fSArtyom Skrobov TEST(getSwappedBytes, uint32_t) {
112ef5e867fSArtyom Skrobov EXPECT_EQ(uint32_t(0x11223344), sys::getSwappedBytes(uint32_t(0x44332211)));
113ded95b79SMichael J. Spencer }
114ded95b79SMichael J. Spencer
TEST(getSwappedBytes,uint64_t)115ef5e867fSArtyom Skrobov TEST(getSwappedBytes, uint64_t) {
116b28ce01eSMichael J. Spencer EXPECT_EQ(uint64_t(0x1122334455667788ULL),
117ef5e867fSArtyom Skrobov sys::getSwappedBytes(uint64_t(0x8877665544332211ULL)));
118ded95b79SMichael J. Spencer }
119ded95b79SMichael J. Spencer
TEST(getSwappedBytes,int8_t)120ef5e867fSArtyom Skrobov TEST(getSwappedBytes, int8_t) {
121ef5e867fSArtyom Skrobov EXPECT_EQ(int8_t(0x11), sys::getSwappedBytes(int8_t(0x11)));
122ded95b79SMichael J. Spencer }
123ded95b79SMichael J. Spencer
TEST(getSwappedBytes,int16_t)124ef5e867fSArtyom Skrobov TEST(getSwappedBytes, int16_t) {
125ef5e867fSArtyom Skrobov EXPECT_EQ(int16_t(0x1122), sys::getSwappedBytes(int16_t(0x2211)));
126ded95b79SMichael J. Spencer }
127ded95b79SMichael J. Spencer
TEST(getSwappedBytes,int32_t)128ef5e867fSArtyom Skrobov TEST(getSwappedBytes, int32_t) {
129ef5e867fSArtyom Skrobov EXPECT_EQ(int32_t(0x11223344), sys::getSwappedBytes(int32_t(0x44332211)));
130ded95b79SMichael J. Spencer }
131ded95b79SMichael J. Spencer
TEST(getSwappedBytes,int64_t)132ef5e867fSArtyom Skrobov TEST(getSwappedBytes, int64_t) {
133b28ce01eSMichael J. Spencer EXPECT_EQ(int64_t(0x1122334455667788LL),
134ef5e867fSArtyom Skrobov sys::getSwappedBytes(int64_t(0x8877665544332211LL)));
135ded95b79SMichael J. Spencer }
136ded95b79SMichael J. Spencer
TEST(getSwappedBytes,float)137c3aeb85fSPawel Bylica TEST(getSwappedBytes, float) {
138c3aeb85fSPawel Bylica EXPECT_EQ(1.79366203433576585078237386661e-43f, sys::getSwappedBytes(-0.0f));
139c3aeb85fSPawel Bylica // 0x11223344
140c3aeb85fSPawel Bylica EXPECT_EQ(7.1653228759765625e2f, sys::getSwappedBytes(1.2795344e-28f));
141c3aeb85fSPawel Bylica }
142c3aeb85fSPawel Bylica
TEST(getSwappedBytes,double)143c3aeb85fSPawel Bylica TEST(getSwappedBytes, double) {
144c3aeb85fSPawel Bylica EXPECT_EQ(6.32404026676795576546008054871e-322, sys::getSwappedBytes(-0.0));
145c3aeb85fSPawel Bylica // 0x1122334455667788
146c3aeb85fSPawel Bylica EXPECT_EQ(-7.08687663657301358331704585496e-268,
147c3aeb85fSPawel Bylica sys::getSwappedBytes(3.84141202447173065923064450234e-226));
148c3aeb85fSPawel Bylica }
149c3aeb85fSPawel Bylica
TEST(swapByteOrder,uint8_t)150e2d6008dSArtyom Skrobov TEST(swapByteOrder, uint8_t) {
151e2d6008dSArtyom Skrobov uint8_t value = 0x11;
152e2d6008dSArtyom Skrobov sys::swapByteOrder(value);
153e2d6008dSArtyom Skrobov EXPECT_EQ(uint8_t(0x11), value);
154e2d6008dSArtyom Skrobov }
155e2d6008dSArtyom Skrobov
TEST(swapByteOrder,uint16_t)156e2d6008dSArtyom Skrobov TEST(swapByteOrder, uint16_t) {
157e2d6008dSArtyom Skrobov uint16_t value = 0x2211;
158e2d6008dSArtyom Skrobov sys::swapByteOrder(value);
159e2d6008dSArtyom Skrobov EXPECT_EQ(uint16_t(0x1122), value);
160e2d6008dSArtyom Skrobov }
161e2d6008dSArtyom Skrobov
TEST(swapByteOrder,uint32_t)162e2d6008dSArtyom Skrobov TEST(swapByteOrder, uint32_t) {
163e2d6008dSArtyom Skrobov uint32_t value = 0x44332211;
164e2d6008dSArtyom Skrobov sys::swapByteOrder(value);
165e2d6008dSArtyom Skrobov EXPECT_EQ(uint32_t(0x11223344), value);
166e2d6008dSArtyom Skrobov }
167e2d6008dSArtyom Skrobov
TEST(swapByteOrder,uint64_t)168e2d6008dSArtyom Skrobov TEST(swapByteOrder, uint64_t) {
169e2d6008dSArtyom Skrobov uint64_t value = 0x8877665544332211ULL;
170e2d6008dSArtyom Skrobov sys::swapByteOrder(value);
171e2d6008dSArtyom Skrobov EXPECT_EQ(uint64_t(0x1122334455667788ULL), value);
172e2d6008dSArtyom Skrobov }
173e2d6008dSArtyom Skrobov
TEST(swapByteOrder,int8_t)174e2d6008dSArtyom Skrobov TEST(swapByteOrder, int8_t) {
175e2d6008dSArtyom Skrobov int8_t value = 0x11;
176e2d6008dSArtyom Skrobov sys::swapByteOrder(value);
177e2d6008dSArtyom Skrobov EXPECT_EQ(int8_t(0x11), value);
178e2d6008dSArtyom Skrobov }
179e2d6008dSArtyom Skrobov
TEST(swapByteOrder,int16_t)180e2d6008dSArtyom Skrobov TEST(swapByteOrder, int16_t) {
181e2d6008dSArtyom Skrobov int16_t value = 0x2211;
182e2d6008dSArtyom Skrobov sys::swapByteOrder(value);
183e2d6008dSArtyom Skrobov EXPECT_EQ(int16_t(0x1122), value);
184e2d6008dSArtyom Skrobov }
185e2d6008dSArtyom Skrobov
TEST(swapByteOrder,int32_t)186e2d6008dSArtyom Skrobov TEST(swapByteOrder, int32_t) {
187e2d6008dSArtyom Skrobov int32_t value = 0x44332211;
188e2d6008dSArtyom Skrobov sys::swapByteOrder(value);
189e2d6008dSArtyom Skrobov EXPECT_EQ(int32_t(0x11223344), value);
190e2d6008dSArtyom Skrobov }
191e2d6008dSArtyom Skrobov
TEST(swapByteOrder,int64_t)192e2d6008dSArtyom Skrobov TEST(swapByteOrder, int64_t) {
193e2d6008dSArtyom Skrobov int64_t value = 0x8877665544332211LL;
194e2d6008dSArtyom Skrobov sys::swapByteOrder(value);
195e2d6008dSArtyom Skrobov EXPECT_EQ(int64_t(0x1122334455667788LL), value);
196e2d6008dSArtyom Skrobov }
197e2d6008dSArtyom Skrobov
TEST(swapByteOrder,float)198c3aeb85fSPawel Bylica TEST(swapByteOrder, float) {
199c3aeb85fSPawel Bylica float value = 7.1653228759765625e2f; // 0x44332211
200c3aeb85fSPawel Bylica sys::swapByteOrder(value);
201c3aeb85fSPawel Bylica EXPECT_EQ(1.2795344e-28f, value);
202c3aeb85fSPawel Bylica }
203c3aeb85fSPawel Bylica
TEST(swapByteOrder,double)204c3aeb85fSPawel Bylica TEST(swapByteOrder, double) {
205c3aeb85fSPawel Bylica double value = -7.08687663657301358331704585496e-268; // 0x8877665544332211
206c3aeb85fSPawel Bylica sys::swapByteOrder(value);
207c3aeb85fSPawel Bylica EXPECT_EQ(3.84141202447173065923064450234e-226, value);
208c3aeb85fSPawel Bylica }
209c3aeb85fSPawel Bylica
210ded95b79SMichael J. Spencer }
211