Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 29 Dec 2015 00:43:46 +0000 (UTC)
From:      Hajimu UMEMOTO <ume@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-stable@freebsd.org, svn-src-stable-9@freebsd.org
Subject:   svn commit: r292851 - stable/9/lib/libc/net
Message-ID:  <201512290043.tBT0hkNs010291@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: ume
Date: Tue Dec 29 00:43:46 2015
New Revision: 292851
URL: https://svnweb.freebsd.org/changeset/base/292851

Log:
  MFC r292550, r292595:
    Simplify _map_v4v6_address().
    We don't need to use a temporary buffer, here.

Modified:
  stable/9/lib/libc/net/map_v4v6.c
Directory Properties:
  stable/9/lib/libc/   (props changed)

Modified: stable/9/lib/libc/net/map_v4v6.c
==============================================================================
--- stable/9/lib/libc/net/map_v4v6.c	Tue Dec 29 00:42:35 2015	(r292850)
+++ stable/9/lib/libc/net/map_v4v6.c	Tue Dec 29 00:43:46 2015	(r292851)
@@ -77,19 +77,11 @@ typedef union {
 void
 _map_v4v6_address(const char *src, char *dst)
 {
-	u_char *p = (u_char *)dst;
-	char tmp[NS_INADDRSZ];
-	int i;
-
-	/* Stash a temporary copy so our caller can update in place. */
-	memcpy(tmp, src, NS_INADDRSZ);
+	/* Our caller may update in place. */
+	memmove(&dst[12], src, NS_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, NS_INADDRSZ);
+	memset(&dst[10], 0xff, 2);
+	memset(&dst[0], 0, 10);
 }
 
 void



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201512290043.tBT0hkNs010291>