| /* | 
 |  * 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 | 
 |   GTEST_SKIP() << "glibc doesn't have htons/htonl/htonq in <endian.h>"; | 
 | #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 | 
 |   GTEST_SKIP() << "glibc doesn't have ntohs/ntohl/ntohq in <endian.h>"; | 
 | #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 | 
 |   GTEST_SKIP() << "glibc doesn't have betoh16/betoh32/betoh64"; | 
 | #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 | 
 |   GTEST_SKIP() << "glibc doesn't have letoh16/letoh32/letoh64"; | 
 | #endif | 
 | } |