1*810390e3Srobert //===- endian_test.cpp ------------------------- swap byte order test -----===//
2*810390e3Srobert //
3*810390e3Srobert // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*810390e3Srobert // See https://llvm.org/LICENSE.txt for license information.
5*810390e3Srobert // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*810390e3Srobert //
7*810390e3Srobert //===----------------------------------------------------------------------===//
8*810390e3Srobert //
9*810390e3Srobert // This file is a part of the ORC runtime.
10*810390e3Srobert //
11*810390e3Srobert // Adapted from the llvm/unittests/Support/SwapByteOrderTest.cpp LLVM unit test.
12*810390e3Srobert //
13*810390e3Srobert //===----------------------------------------------------------------------===//
14*810390e3Srobert
15*810390e3Srobert #include "endianness.h"
16*810390e3Srobert #include "gtest/gtest.h"
17*810390e3Srobert
18*810390e3Srobert using namespace __orc_rt;
19*810390e3Srobert
TEST(Endian,ByteSwap_32)20*810390e3Srobert TEST(Endian, ByteSwap_32) {
21*810390e3Srobert EXPECT_EQ(0x44332211u, ByteSwap_32(0x11223344));
22*810390e3Srobert EXPECT_EQ(0xDDCCBBAAu, ByteSwap_32(0xAABBCCDD));
23*810390e3Srobert }
24*810390e3Srobert
TEST(Endian,ByteSwap_64)25*810390e3Srobert TEST(Endian, ByteSwap_64) {
26*810390e3Srobert EXPECT_EQ(0x8877665544332211ULL, ByteSwap_64(0x1122334455667788LL));
27*810390e3Srobert EXPECT_EQ(0x1100FFEEDDCCBBAAULL, ByteSwap_64(0xAABBCCDDEEFF0011LL));
28*810390e3Srobert }
29*810390e3Srobert
30*810390e3Srobert // In these first two tests all of the original_uintx values are truncated
31*810390e3Srobert // except for 64. We could avoid this, but there's really no point.
TEST(Endian,getSwappedBytes_UnsignedRoundTrip)32*810390e3Srobert TEST(Endian, getSwappedBytes_UnsignedRoundTrip) {
33*810390e3Srobert // The point of the bit twiddling of magic is to test with and without bits
34*810390e3Srobert // in every byte.
35*810390e3Srobert uint64_t value = 1;
36*810390e3Srobert for (std::size_t i = 0; i <= sizeof(value); ++i) {
37*810390e3Srobert uint8_t original_uint8 = static_cast<uint8_t>(value);
38*810390e3Srobert EXPECT_EQ(original_uint8, getSwappedBytes(getSwappedBytes(original_uint8)));
39*810390e3Srobert
40*810390e3Srobert uint16_t original_uint16 = static_cast<uint16_t>(value);
41*810390e3Srobert EXPECT_EQ(original_uint16,
42*810390e3Srobert getSwappedBytes(getSwappedBytes(original_uint16)));
43*810390e3Srobert
44*810390e3Srobert uint32_t original_uint32 = static_cast<uint32_t>(value);
45*810390e3Srobert EXPECT_EQ(original_uint32,
46*810390e3Srobert getSwappedBytes(getSwappedBytes(original_uint32)));
47*810390e3Srobert
48*810390e3Srobert uint64_t original_uint64 = static_cast<uint64_t>(value);
49*810390e3Srobert EXPECT_EQ(original_uint64,
50*810390e3Srobert getSwappedBytes(getSwappedBytes(original_uint64)));
51*810390e3Srobert
52*810390e3Srobert value = (value << 8) | 0x55; // binary 0101 0101.
53*810390e3Srobert }
54*810390e3Srobert }
55*810390e3Srobert
TEST(Endian,getSwappedBytes_SignedRoundTrip)56*810390e3Srobert TEST(Endian, getSwappedBytes_SignedRoundTrip) {
57*810390e3Srobert // The point of the bit twiddling of magic is to test with and without bits
58*810390e3Srobert // in every byte.
59*810390e3Srobert uint64_t value = 1;
60*810390e3Srobert for (std::size_t i = 0; i <= sizeof(value); ++i) {
61*810390e3Srobert int8_t original_int8 = static_cast<int8_t>(value);
62*810390e3Srobert EXPECT_EQ(original_int8, getSwappedBytes(getSwappedBytes(original_int8)));
63*810390e3Srobert
64*810390e3Srobert int16_t original_int16 = static_cast<int16_t>(value);
65*810390e3Srobert EXPECT_EQ(original_int16, getSwappedBytes(getSwappedBytes(original_int16)));
66*810390e3Srobert
67*810390e3Srobert int32_t original_int32 = static_cast<int32_t>(value);
68*810390e3Srobert EXPECT_EQ(original_int32, getSwappedBytes(getSwappedBytes(original_int32)));
69*810390e3Srobert
70*810390e3Srobert int64_t original_int64 = static_cast<int64_t>(value);
71*810390e3Srobert EXPECT_EQ(original_int64, getSwappedBytes(getSwappedBytes(original_int64)));
72*810390e3Srobert
73*810390e3Srobert // Test other sign.
74*810390e3Srobert value *= -1;
75*810390e3Srobert
76*810390e3Srobert original_int8 = static_cast<int8_t>(value);
77*810390e3Srobert EXPECT_EQ(original_int8, getSwappedBytes(getSwappedBytes(original_int8)));
78*810390e3Srobert
79*810390e3Srobert original_int16 = static_cast<int16_t>(value);
80*810390e3Srobert EXPECT_EQ(original_int16, getSwappedBytes(getSwappedBytes(original_int16)));
81*810390e3Srobert
82*810390e3Srobert original_int32 = static_cast<int32_t>(value);
83*810390e3Srobert EXPECT_EQ(original_int32, getSwappedBytes(getSwappedBytes(original_int32)));
84*810390e3Srobert
85*810390e3Srobert original_int64 = static_cast<int64_t>(value);
86*810390e3Srobert EXPECT_EQ(original_int64, getSwappedBytes(getSwappedBytes(original_int64)));
87*810390e3Srobert
88*810390e3Srobert // Return to normal sign and twiddle.
89*810390e3Srobert value *= -1;
90*810390e3Srobert value = (value << 8) | 0x55; // binary 0101 0101.
91*810390e3Srobert }
92*810390e3Srobert }
93*810390e3Srobert
TEST(Endian,getSwappedBytes_uint8_t)94*810390e3Srobert TEST(Endian, getSwappedBytes_uint8_t) {
95*810390e3Srobert EXPECT_EQ(uint8_t(0x11), getSwappedBytes(uint8_t(0x11)));
96*810390e3Srobert }
97*810390e3Srobert
TEST(Endian,getSwappedBytes_uint16_t)98*810390e3Srobert TEST(Endian, getSwappedBytes_uint16_t) {
99*810390e3Srobert EXPECT_EQ(uint16_t(0x1122), getSwappedBytes(uint16_t(0x2211)));
100*810390e3Srobert }
101*810390e3Srobert
TEST(Endian,getSwappedBytes_uint32_t)102*810390e3Srobert TEST(Endian, getSwappedBytes_uint32_t) {
103*810390e3Srobert EXPECT_EQ(uint32_t(0x11223344), getSwappedBytes(uint32_t(0x44332211)));
104*810390e3Srobert }
105*810390e3Srobert
TEST(Endian,getSwappedBytes_uint64_t)106*810390e3Srobert TEST(Endian, getSwappedBytes_uint64_t) {
107*810390e3Srobert EXPECT_EQ(uint64_t(0x1122334455667788ULL),
108*810390e3Srobert getSwappedBytes(uint64_t(0x8877665544332211ULL)));
109*810390e3Srobert }
110*810390e3Srobert
TEST(Endian,getSwappedBytes_int8_t)111*810390e3Srobert TEST(Endian, getSwappedBytes_int8_t) {
112*810390e3Srobert EXPECT_EQ(int8_t(0x11), getSwappedBytes(int8_t(0x11)));
113*810390e3Srobert }
114*810390e3Srobert
TEST(Endian,getSwappedBytes_int16_t)115*810390e3Srobert TEST(Endian, getSwappedBytes_int16_t) {
116*810390e3Srobert EXPECT_EQ(int16_t(0x1122), getSwappedBytes(int16_t(0x2211)));
117*810390e3Srobert }
118*810390e3Srobert
TEST(Endian,getSwappedBytes_int32_t)119*810390e3Srobert TEST(Endian, getSwappedBytes_int32_t) {
120*810390e3Srobert EXPECT_EQ(int32_t(0x11223344), getSwappedBytes(int32_t(0x44332211)));
121*810390e3Srobert }
122*810390e3Srobert
TEST(Endian,getSwappedBytes_int64_t)123*810390e3Srobert TEST(Endian, getSwappedBytes_int64_t) {
124*810390e3Srobert EXPECT_EQ(int64_t(0x1122334455667788LL),
125*810390e3Srobert getSwappedBytes(int64_t(0x8877665544332211LL)));
126*810390e3Srobert }
127*810390e3Srobert
TEST(Endian,swapByteOrder_uint8_t)128*810390e3Srobert TEST(Endian, swapByteOrder_uint8_t) {
129*810390e3Srobert uint8_t value = 0x11;
130*810390e3Srobert swapByteOrder(value);
131*810390e3Srobert EXPECT_EQ(uint8_t(0x11), value);
132*810390e3Srobert }
133*810390e3Srobert
TEST(Endian,swapByteOrder_uint16_t)134*810390e3Srobert TEST(Endian, swapByteOrder_uint16_t) {
135*810390e3Srobert uint16_t value = 0x2211;
136*810390e3Srobert swapByteOrder(value);
137*810390e3Srobert EXPECT_EQ(uint16_t(0x1122), value);
138*810390e3Srobert }
139*810390e3Srobert
TEST(Endian,swapByteOrder_uint32_t)140*810390e3Srobert TEST(Endian, swapByteOrder_uint32_t) {
141*810390e3Srobert uint32_t value = 0x44332211;
142*810390e3Srobert swapByteOrder(value);
143*810390e3Srobert EXPECT_EQ(uint32_t(0x11223344), value);
144*810390e3Srobert }
145*810390e3Srobert
TEST(Endian,swapByteOrder_uint64_t)146*810390e3Srobert TEST(Endian, swapByteOrder_uint64_t) {
147*810390e3Srobert uint64_t value = 0x8877665544332211ULL;
148*810390e3Srobert swapByteOrder(value);
149*810390e3Srobert EXPECT_EQ(uint64_t(0x1122334455667788ULL), value);
150*810390e3Srobert }
151*810390e3Srobert
TEST(Endian,swapByteOrder_int8_t)152*810390e3Srobert TEST(Endian, swapByteOrder_int8_t) {
153*810390e3Srobert int8_t value = 0x11;
154*810390e3Srobert swapByteOrder(value);
155*810390e3Srobert EXPECT_EQ(int8_t(0x11), value);
156*810390e3Srobert }
157*810390e3Srobert
TEST(Endian,swapByteOrder_int16_t)158*810390e3Srobert TEST(Endian, swapByteOrder_int16_t) {
159*810390e3Srobert int16_t value = 0x2211;
160*810390e3Srobert swapByteOrder(value);
161*810390e3Srobert EXPECT_EQ(int16_t(0x1122), value);
162*810390e3Srobert }
163*810390e3Srobert
TEST(Endian,swapByteOrder_int32_t)164*810390e3Srobert TEST(Endian, swapByteOrder_int32_t) {
165*810390e3Srobert int32_t value = 0x44332211;
166*810390e3Srobert swapByteOrder(value);
167*810390e3Srobert EXPECT_EQ(int32_t(0x11223344), value);
168*810390e3Srobert }
169*810390e3Srobert
TEST(Endian,swapByteOrder_int64_t)170*810390e3Srobert TEST(Endian, swapByteOrder_int64_t) {
171*810390e3Srobert int64_t value = 0x8877665544332211LL;
172*810390e3Srobert swapByteOrder(value);
173*810390e3Srobert EXPECT_EQ(int64_t(0x1122334455667788LL), value);
174*810390e3Srobert }
175