From: Ulrich Drepper Date: Tue, 21 Nov 2006 00:33:33 +0000 (+0000) Subject: * resolv/mapv4v6addr.h (map_v4v6_address): Optimize a bit. X-Git-Tag: cvs/fedora-glibc-20061128T1037~2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=dfc99a56514db15abe8e00aface9cd2be831f447;p=platform%2Fupstream%2Fglibc.git * resolv/mapv4v6addr.h (map_v4v6_address): Optimize a bit. --- diff --git a/ChangeLog b/ChangeLog index 7eb3ae0..f4c0a0a 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2006-11-20 Ulrich Drepper + + * resolv/mapv4v6addr.h (map_v4v6_address): Optimize a bit. + 2006-11-18 Bruno Haible * sysdeps/unix/sysv/linux/i386/getgroups.c (__getgroups): Invoke diff --git a/resolv/mapv4v6addr.h b/resolv/mapv4v6addr.h index bc3290f..a71a6cc 100644 --- a/resolv/mapv4v6addr.h +++ b/resolv/mapv4v6addr.h @@ -56,16 +56,14 @@ static void map_v4v6_address (const char *src, char *dst) { u_char *p = (u_char *) dst; - char tmp[INADDRSZ]; int i; - /* Stash a temporary copy so our caller can update in place. */ - memcpy (tmp, src, INADDRSZ); + /* Move the IPv4 part to the right position. */ + memcpy (src + 12, src, INADDRSZ); + /* Mark this ipv6 addr as a mapped ipv4. */ for (i = 0; i < 10; i++) *p++ = 0x00; *p++ = 0xff; - *p++ = 0xff; - /* Retrieve the saved copy and we're done. */ - memcpy ((void *) p, tmp, INADDRSZ); + *p = 0xff; }