On little endian architectures, use LWIP_PLATFORM_HTONS (if defined) for SWAP_BYTES_IN_WORD to speed up checksumming.

This commit is contained in:
goldsimon 2009-05-06 17:35:50 +00:00
parent ac9e758f41
commit 95f6dc7011
2 changed files with 11 additions and 0 deletions

View File

@ -99,6 +99,10 @@ HISTORY
++ Bugfixes: ++ Bugfixes:
2009-05-06 Simon Goldschmidt
* inet_chksum.c: On little endian architectures, use LWIP_PLATFORM_HTONS (if
defined) for SWAP_BYTES_IN_WORD to speed up checksumming.
2009-05-05 Simon Goldschmidt 2009-05-05 Simon Goldschmidt
* sockets.c: bug #26405: Prematurely released semaphore causes lwip_select() * sockets.c: bug #26405: Prematurely released semaphore causes lwip_select()
to crash to crash

View File

@ -64,7 +64,14 @@
#endif #endif
/** Like the name says... */ /** Like the name says... */
#if LWIP_PLATFORM_BYTESWAP && (BYTE_ORDER == LITTLE_ENDIAN)
/* little endian and PLATFORM_BYTESWAP defined */
#define SWAP_BYTES_IN_WORD(w) LWIP_PLATFORM_HTONS(x)
#else
/* can't use htons on big endian (or PLATFORM_BYTESWAP not defined)... */
#define SWAP_BYTES_IN_WORD(w) ((w & 0xff) << 8) | ((w & 0xff00) >> 8) #define SWAP_BYTES_IN_WORD(w) ((w & 0xff) << 8) | ((w & 0xff00) >> 8)
#endif
/** Split an u32_t in two u16_ts and add them up */ /** Split an u32_t in two u16_ts and add them up */
#define FOLD_U32T(u) ((u >> 16) + (u & 0x0000ffffUL)) #define FOLD_U32T(u) ((u >> 16) + (u & 0x0000ffffUL))