From db92e66902c691ca0d5dff8ec91e41c63149dc36 Mon Sep 17 00:00:00 2001 From: Peter Elliott Date: Fri, 23 Jul 2021 16:07:46 -0600 Subject: [PATCH] LibC: Make more POSIX compliant 1. Move htonl() etc. from to (which includes). The htonl(), htons(), ntohl(), and ntohs() functions shall be available as described in . Inclusion of the header may also make visible all symbols from . - POSIX 2. Define IN6_IS_ADDR_LOOPBACK() and IN6_IS_ADDR_V4MAPPED() --- Userland/Libraries/LibC/arpa/inet.h | 29 ----------------------- Userland/Libraries/LibC/netinet/in.h | 35 ++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+), 29 deletions(-) diff --git a/Userland/Libraries/LibC/arpa/inet.h b/Userland/Libraries/LibC/arpa/inet.h index 44200357d00..3ba673731f7 100644 --- a/Userland/Libraries/LibC/arpa/inet.h +++ b/Userland/Libraries/LibC/arpa/inet.h @@ -6,7 +6,6 @@ #pragma once -#include #include #include #include @@ -27,32 +26,4 @@ static inline int inet_aton(const char* cp, struct in_addr* inp) char* inet_ntoa(struct in_addr); -static inline uint16_t htons(uint16_t value) -{ -#if __BYTE_ORDER == __LITTLE_ENDIAN - return __builtin_bswap16(value); -#else - return value; -#endif -} - -static inline uint16_t ntohs(uint16_t value) -{ - return htons(value); -} - -static inline uint32_t htonl(uint32_t value) -{ -#if __BYTE_ORDER == __LITTLE_ENDIAN - return __builtin_bswap32(value); -#else - return value; -#endif -} - -static inline uint32_t ntohl(uint32_t value) -{ - return htonl(value); -} - __END_DECLS diff --git a/Userland/Libraries/LibC/netinet/in.h b/Userland/Libraries/LibC/netinet/in.h index 6d389892ddb..7be4b579a65 100644 --- a/Userland/Libraries/LibC/netinet/in.h +++ b/Userland/Libraries/LibC/netinet/in.h @@ -7,9 +7,44 @@ #pragma once #include +#include __BEGIN_DECLS in_addr_t inet_addr(char const*); +static inline uint16_t htons(uint16_t value) +{ +#if __BYTE_ORDER == __LITTLE_ENDIAN + return __builtin_bswap16(value); +#else + return value; +#endif +} + +static inline uint16_t ntohs(uint16_t value) +{ + return htons(value); +} + +static inline uint32_t htonl(uint32_t value) +{ +#if __BYTE_ORDER == __LITTLE_ENDIAN + return __builtin_bswap32(value); +#else + return value; +#endif +} + +static inline uint32_t ntohl(uint32_t value) +{ + return htonl(value); +} + +#define IN6_IS_ADDR_LOOPBACK(addr) \ + (addr->s6_addr[0] == 0 && addr->s6_addr[1] == 0 && addr->s6_addr[2] == 0 && addr->s6_addr[3] == 0 && addr->s6_addr[4] == 0 && addr->s6_addr[5] == 0 && addr->s6_addr[6] == 0 && addr->s6_addr[7] == 0 && addr->s6_addr[8] == 0 && addr->s6_addr[9] == 0 && addr->s6_addr[10] == 0 && addr->s6_addr[11] == 0 && addr->s6_addr[12] == 0 && addr->s6_addr[13] == 0 && addr->s6_addr[14] == 0 && addr->s6_addr[15] == 1) + +#define IN6_IS_ADDR_V4MAPPED(addr) \ + (addr->s6_addr[0] == 0 && addr->s6_addr[1] == 0 && addr->s6_addr[2] == 0 && addr->s6_addr[3] == 0 && addr->s6_addr[4] == 0 && addr->s6_addr[5] == 0 && addr->s6_addr[6] == 0 && addr->s6_addr[7] == 0 && addr->s6_addr[8] == 0xff && addr->s6_addr[9] == 0xff && addr->s6_addr[10] == 0xff && addr->s6_addr[11] == 0xff) + __END_DECLS