2017-02-25 00:19:53 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <endian.h>
|
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
static constexpr uint16_t le16 = 0x1234;
|
|
|
|
static constexpr uint32_t le32 = 0x12345678;
|
|
|
|
static constexpr uint64_t le64 = 0x123456789abcdef0;
|
|
|
|
|
|
|
|
static constexpr uint16_t be16 = 0x3412;
|
|
|
|
static constexpr uint32_t be32 = 0x78563412;
|
|
|
|
static constexpr uint64_t be64 = 0xf0debc9a78563412;
|
|
|
|
|
|
|
|
TEST(endian, constants) {
|
|
|
|
ASSERT_TRUE(__LITTLE_ENDIAN == LITTLE_ENDIAN);
|
|
|
|
ASSERT_TRUE(__BIG_ENDIAN == BIG_ENDIAN);
|
|
|
|
ASSERT_TRUE(__BYTE_ORDER == BYTE_ORDER);
|
|
|
|
|
|
|
|
#if defined(__BIONIC__)
|
|
|
|
ASSERT_TRUE(_LITTLE_ENDIAN == LITTLE_ENDIAN);
|
|
|
|
ASSERT_TRUE(_BIG_ENDIAN == BIG_ENDIAN);
|
|
|
|
ASSERT_TRUE(_BYTE_ORDER == BYTE_ORDER);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
ASSERT_EQ(__LITTLE_ENDIAN, __BYTE_ORDER);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(endian, htons_htonl_htonq_macros) {
|
|
|
|
#if defined(__BIONIC__)
|
|
|
|
ASSERT_EQ(be16, htons(le16));
|
|
|
|
ASSERT_EQ(be32, htonl(le32));
|
|
|
|
ASSERT_EQ(be64, htonq(le64));
|
|
|
|
#else
|
2019-03-08 23:20:23 +00:00
|
|
|
GTEST_SKIP() << "glibc doesn't have htons/htonl/htonq in <endian.h>";
|
2017-02-25 00:19:53 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(endian, ntohs_ntohl_ntohq_macros) {
|
|
|
|
#if defined(__BIONIC__)
|
|
|
|
ASSERT_EQ(le16, ntohs(be16));
|
|
|
|
ASSERT_EQ(le32, ntohl(be32));
|
|
|
|
ASSERT_EQ(le64, ntohq(be64));
|
|
|
|
#else
|
2019-03-08 23:20:23 +00:00
|
|
|
GTEST_SKIP() << "glibc doesn't have ntohs/ntohl/ntohq in <endian.h>";
|
2017-02-25 00:19:53 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(endian, htobe16_htobe32_htobe64) {
|
|
|
|
ASSERT_EQ(be16, htobe16(le16));
|
|
|
|
ASSERT_EQ(be32, htobe32(le32));
|
|
|
|
ASSERT_EQ(be64, htobe64(le64));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(endian, htole16_htole32_htole64) {
|
|
|
|
ASSERT_EQ(le16, htole16(le16));
|
|
|
|
ASSERT_EQ(le32, htole32(le32));
|
|
|
|
ASSERT_EQ(le64, htole64(le64));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(endian, be16toh_be32toh_be64toh) {
|
|
|
|
ASSERT_EQ(le16, be16toh(be16));
|
|
|
|
ASSERT_EQ(le32, be32toh(be32));
|
|
|
|
ASSERT_EQ(le64, be64toh(be64));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(endian, le16toh_le32toh_le64toh) {
|
|
|
|
ASSERT_EQ(le16, le16toh(le16));
|
|
|
|
ASSERT_EQ(le32, le32toh(le32));
|
|
|
|
ASSERT_EQ(le64, le64toh(le64));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(endian, betoh16_betoh32_betoh64) {
|
|
|
|
#if defined(__BIONIC__)
|
|
|
|
ASSERT_EQ(le16, betoh16(be16));
|
|
|
|
ASSERT_EQ(le32, betoh32(be32));
|
|
|
|
ASSERT_EQ(le64, betoh64(be64));
|
|
|
|
#else
|
2019-03-08 23:20:23 +00:00
|
|
|
GTEST_SKIP() << "glibc doesn't have betoh16/betoh32/betoh64";
|
2017-02-25 00:19:53 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(endian, letoh16_letoh32_letoh64) {
|
|
|
|
#if defined(__BIONIC__)
|
|
|
|
ASSERT_EQ(le16, letoh16(le16));
|
|
|
|
ASSERT_EQ(le32, letoh32(le32));
|
|
|
|
ASSERT_EQ(le64, letoh64(le64));
|
|
|
|
#else
|
2019-03-08 23:20:23 +00:00
|
|
|
GTEST_SKIP() << "glibc doesn't have letoh16/letoh32/letoh64";
|
2017-02-25 00:19:53 +00:00
|
|
|
#endif
|
|
|
|
}
|