From bbfe945f4001c70eab6584f9c217072bb92a5f8a Mon Sep 17 00:00:00 2001 From: Xiang Xiao Date: Wed, 18 Oct 2023 16:42:33 +0800 Subject: [PATCH] endian: Make all endian related functions use the expicit type so the printf can give the unambiguous format specifier Signed-off-by: Xiang Xiao --- include/netinet/in.h | 19 +++++---------- include/sys/endian.h | 56 ++++++++++++++++++++++---------------------- 2 files changed, 34 insertions(+), 41 deletions(-) diff --git a/include/netinet/in.h b/include/netinet/in.h index 3ab5712330eb2..a6038a474d7c3 100644 --- a/include/netinet/in.h +++ b/include/netinet/in.h @@ -230,19 +230,12 @@ * for uIP: */ -#ifdef CONFIG_ENDIAN_BIG -# define HTONS(ns) (ns) -# define HTONL(nl) (nl) -# define HTONQ(nq) (nq) -#else -# define HTONS __swap_uint16 -# define HTONL __swap_uint32 -# define HTONQ __swap_uint64 -#endif - -#define NTOHS(hs) HTONS(hs) -#define NTOHL(hl) HTONL(hl) -#define NTOHQ(hq) HTONQ(hq) +#define HTONS htobe16 +#define HTONL htobe32 +#define HTONQ htobe64 +#define NTOHS be16toh +#define NTOHL be32toh +#define NTOHQ be64toh /**************************************************************************** * Public Type Definitions diff --git a/include/sys/endian.h b/include/sys/endian.h index 41a94c3203044..a2b3789d5d52a 100644 --- a/include/sys/endian.h +++ b/include/sys/endian.h @@ -52,7 +52,7 @@ /* Common byte swapping macros */ #ifdef CONFIG_HAVE_BUILTIN_BSWAP16 -# define __swap_uint16 __builtin_bswap16 +# define __swap_uint16(n) ((uint16_t)__builtin_bswap16(n)) #else # define __swap_uint16(n) \ (uint16_t)(((((uint16_t)(n)) & 0x00ff) << 8) | \ @@ -60,7 +60,7 @@ #endif #ifdef CONFIG_HAVE_BUILTIN_BSWAP32 -# define __swap_uint32 __builtin_bswap32 +# define __swap_uint32(n) ((uint32_t)__builtin_bswap32(n)) #else # define __swap_uint32(n) \ (uint32_t)(((((uint32_t)(n)) & 0x000000ffUL) << 24) | \ @@ -71,7 +71,7 @@ #ifdef CONFIG_HAVE_LONG_LONG # ifdef CONFIG_HAVE_BUILTIN_BSWAP64 -# define __swap_uint64 __builtin_bswap64 +# define __swap_uint64(n) ((uint64_t)__builtin_bswap64(n)) # else # define __swap_uint64(n) \ (uint64_t)(((((uint64_t)(n)) & 0x00000000000000ffULL) << 56) | \ @@ -95,21 +95,21 @@ /* Big-endian byte order macros */ -# define htobe16(n) (n) -# define htole16(n) __swap_uint16((uint16_t)n) -# define be16toh(n) (n) -# define le16toh(n) __swap_uint16((uint16_t)n) +# define htobe16(n) ((uint16_t)(n)) +# define htole16(n) __swap_uint16(n) +# define be16toh(n) ((uint16_t)(n)) +# define le16toh(n) __swap_uint16(n) -# define htobe32(n) (n) -# define htole32(n) __swap_uint32((uint32_t)n) -# define be32toh(n) (n) +# define htobe32(n) ((uint32_t)(n)) +# define htole32(n) __swap_uint32(n) +# define be32toh(n) ((uint32_t)(n)) # define le32toh(n) __swap_uint32(n) # ifdef CONFIG_HAVE_LONG_LONG -# define htobe64(n) (n) -# define htole64(n) __swap_uint64((uint64_t)n) -# define be64toh(n) (n) -# define le64toh(n) __swap_uint64((uint64_t)n) +# define htobe64(n) ((uint64_t)(n)) +# define htole64(n) __swap_uint64(n) +# define be64toh(n) ((uint64_t)(n)) +# define le64toh(n) __swap_uint64(n) # endif #else @@ -120,21 +120,21 @@ /* Little-endian byte order macros */ -# define htobe16(n) __swap_uint16((uint16_t)n) -# define htole16(n) (n) -# define be16toh(n) __swap_uint16((uint16_t)n) -# define le16toh(n) (n) +# define htobe16(n) __swap_uint16(n) +# define htole16(n) ((uint16_t)(n)) +# define be16toh(n) __swap_uint16(n) +# define le16toh(n) ((uint16_t)(n)) -# define htobe32(n) __swap_uint32((uint32_t)n) -# define htole32(n) (n) -# define be32toh(n) __swap_uint32((uint32_t)n) -# define le32toh(n) (n) +# define htobe32(n) __swap_uint32(n) +# define htole32(n) ((uint32_t)(n)) +# define be32toh(n) __swap_uint32(n) +# define le32toh(n) ((uint32_t)(n)) # ifdef CONFIG_HAVE_LONG_LONG -# define htobe64(n) __swap_uint64((uint64_t)n) -# define htole64(n) (n) -# define be64toh(n) __swap_uint64((uint64_t)n) -# define le64toh(n) (n) +# define htobe64(n) __swap_uint64(n) +# define htole64(n) ((uint64_t)(n)) +# define be64toh(n) __swap_uint64(n) +# define le64toh(n) ((uint64_t)(n)) # endif #endif @@ -152,7 +152,7 @@ #define htolem16(x, v) (*(FAR uint16_t *)(x) = htole16(v)) #define betoh32 be32toh #define letoh32 le32toh -#define bemtoh32(x) htobe32(*(FAR uint32_t *)(x)) +#define bemtoh32(x) betoh32(*(FAR uint32_t *)(x)) #define htobem32(x, v) (*(FAR uint32_t *)(x) = htobe32(v)) #define lemtoh32(x) letoh32(*(FAR uint32_t *)(x)) #define htolem32(x, v) (*(FAR uint32_t *)(x) = htole32(v)) @@ -160,7 +160,7 @@ #ifdef CONFIG_HAVE_LONG_LONG # define betoh64 be64toh # define letoh64 le64toh -# define bemtoh64(x) htobe64(*(FAR uint64_t *)(x)) +# define bemtoh64(x) betoh64(*(FAR uint64_t *)(x)) # define htobem64(x, v) (*(FAR uint64_t *)(x) = htobe64(v)) # define lemtoh64(x) letoh64(*(FAR uint64_t *)(x)) # define htolem64(x, v) (*(FAR uint64_t *)(x) = htole64(v))