summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authordes <des@FreeBSD.org>2004-07-06 09:22:18 +0000
committerdes <des@FreeBSD.org>2004-07-06 09:22:18 +0000
commitc05f2ebe921742f142496c086120ee8a02d16b90 (patch)
tree07a2be27b9b9801ab65c5c3c5c01c3f0a04290a9 /lib
parent3a60494e7441500d46a926d8bc5110e93cda5667 (diff)
downloadFreeBSD-src-c05f2ebe921742f142496c086120ee8a02d16b90.zip
FreeBSD-src-c05f2ebe921742f142496c086120ee8a02d16b90.tar.gz
Rewrite twowords() to access its argument through a char pointer and not
a short pointer. The previous implementation seems to be in a gray zone of the C standard, and GCC generates incorrect code for it at -O2 or higher on some platforms.
Diffstat (limited to 'lib')
-rw-r--r--lib/libalias/alias.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/lib/libalias/alias.c b/lib/libalias/alias.c
index 8321900..6acf03b 100644
--- a/lib/libalias/alias.c
+++ b/lib/libalias/alias.c
@@ -139,9 +139,16 @@ __FBSDID("$FreeBSD$");
static __inline int
twowords(void *p)
{
- u_short *s = p;
-
- return (s[0] + s[1]);
+ uint8_t *c = p;
+
+#if BYTE_ORDER == LITTLE_ENDIAN
+ uint16_t s1 = ((uint16_t)c[1] << 8) + (uint16_t)c[0];
+ uint16_t s2 = ((uint16_t)c[3] << 8) + (uint16_t)c[2];
+#else
+ uint16_t s1 = ((uint16_t)c[0] << 8) + (uint16_t)c[1];
+ uint16_t s2 = ((uint16_t)c[2] << 8) + (uint16_t)c[3];
+#endif
+ return (s1 + s2);
}
/* TCP Handling Routines
OpenPOWER on IntegriCloud