aboutsummaryrefslogtreecommitdiff
path: root/inet
diff options
context:
space:
mode:
Diffstat (limited to 'inet')
-rw-r--r--inet/Makefile2
-rw-r--r--inet/netinet/in.h35
2 files changed, 32 insertions, 5 deletions
diff --git a/inet/Makefile b/inet/Makefile
index 847d994478..47570f131c 100644
--- a/inet/Makefile
+++ b/inet/Makefile
@@ -27,7 +27,7 @@ headers := netinet/ether.h netinet/in.h netinet/if_ether.h \
distribute := netgroup.h
-routines := ntohl ntohs htonl htons \
+routines := htonl htons \
inet_lnaof inet_mkadr \
inet_netof inet_ntoa inet_net herrno \
gethstbyad gethstbyad_r gethstbynm gethstbynm2 gethstbynm2_r \
diff --git a/inet/netinet/in.h b/inet/netinet/in.h
index 33f88064e1..ac0d167287 100644
--- a/inet/netinet/in.h
+++ b/inet/netinet/in.h
@@ -210,9 +210,13 @@ struct ipv6_mreq
this was a short-sighted decision since on different systems the types
may have different representations but the values are always the same. */
+extern u_int32_t __ntohl __P ((u_int32_t __netlong));
extern u_int32_t ntohl __P ((u_int32_t __netlong));
+extern u_int16_t __ntohs __P ((u_int16_t __netshort));
extern u_int16_t ntohs __P ((u_int16_t __netshort));
+extern u_int32_t __htonl __P ((u_int32_t __hostlong));
extern u_int32_t htonl __P ((u_int32_t __hostlong));
+extern u_int16_t __htons __P ((u_int16_t __hostshort));
extern u_int16_t htons __P ((u_int16_t __hostshort));
#include <endian.h>
@@ -220,10 +224,33 @@ extern u_int16_t htons __P ((u_int16_t __hostshort));
#if __BYTE_ORDER == __BIG_ENDIAN
/* The host byte order is the same as network byte order,
so these functions are all just identity. */
-#define ntohl(x) (x)
-#define ntohs(x) (x)
-#define htonl(x) (x)
-#define htons(x) (x)
+# define ntohl(x) (x)
+# define ntohs(x) (x)
+# define htonl(x) (x)
+# define htons(x) (x)
+#else
+# if __BYTE_ORDER == __LITTLE_ENDIAN && defined __OPTIMIZE__
+# define ntohl(x) (__builtin_constant_p (x) \
+ ? __constant_htontohl (x) : __ntohl (x))
+# define ntohs(x) (__builtin_constant_p (x) \
+ ? __constant_htontohs (x) : __ntohs (x))
+# define htonl(x) (__builtin_constant_p (x) \
+ ? __constant_htontohl (x) : __htonl (x))
+# define htons(x) (__builtin_constant_p (x) \
+ ? __constant_htontohl (x) : __htonl (x))
+
+# define __constant_htontohl(x) \
+ ((((x) & 0xff000000) >> 24) | \
+ (((x) & 0x00ff0000) >> 8) | \
+ (((x) & 0x0000ff00) << 8) | \
+ (((x) & 0x000000ff) << 24))
+# define __constant_htontohs(x) \
+ ((((x) & 0x0000ff00) >> 8) | \
+ (((x) & 0x000000ff) << 8))
+
+/* Now get machine dependent optimized versions for the real work. */
+# include <bits/htontoh.h>
+# endif
#endif
#define IN6_IS_ADDR_UNSPECIFIED(a) \