summaryrefslogtreecommitdiff
path: root/src/network/htonl.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2011-04-12 13:13:27 -0400
committerRich Felker <dalias@aerifal.cx>2011-04-12 13:13:27 -0400
commitc89862660bd3845ace7977480db3a43dc80475f4 (patch)
tree4b3c890588e359f7e7674898acecbe1aacd95336 /src/network/htonl.c
parentc546be175c169399420fff4706cd1d4fcefd7d31 (diff)
downloadmusl-c89862660bd3845ace7977480db3a43dc80475f4.tar.gz
musl-c89862660bd3845ace7977480db3a43dc80475f4.tar.bz2
musl-c89862660bd3845ace7977480db3a43dc80475f4.tar.xz
musl-c89862660bd3845ace7977480db3a43dc80475f4.zip
optimize ntohl etc. in terms of bswap functions
we can do this without violating the namespace now that they are macros/inline functions rather than extern functions. the motivation is that gcc was generating giant, slow, horrible code for the old functions, and now generates a single byte-swapping instruction.
Diffstat (limited to 'src/network/htonl.c')
-rw-r--r--src/network/htonl.c8
1 files changed, 3 insertions, 5 deletions
diff --git a/src/network/htonl.c b/src/network/htonl.c
index b21dace0..6622d16c 100644
--- a/src/network/htonl.c
+++ b/src/network/htonl.c
@@ -1,10 +1,8 @@
#include <netinet/in.h>
+#include <byteswap.h>
uint32_t htonl(uint32_t n)
{
- union {
- uint8_t b[4];
- uint32_t i;
- } u = { { n>>24, n>>16, n>>8, n } };
- return u.i;
+ union { int i; char c; } u = { 1 };
+ return u.c ? bswap_32(n) : n;
}