Blame SOURCES/rpcbind-0.2.0-warnings.patch

3da827
commit d62f79d7905149719715f74c188b47d7911c928c
3da827
Author: Steve Dickson <steved@redhat.com>
3da827
Date:   Mon Aug 18 11:44:19 2014 -0400
3da827
3da827
    rpcbind: Remove a strict-aliasing warning
3da827
    
3da827
    src/util.c: In function ?in6_fillscopeid?:
3da827
    src/util.c:106:3: warning: dereferencing type-punned pointer will break
3da827
    strict-aliasing rules [-Wstrict-aliasing]
3da827
       ifindex = ntohs(*(u_int16_t *)&sin6->sin6_addr.s6_addr[2]);
3da827
       ^
3da827
    
3da827
    src/util.c:109:4: warning: dereferencing type-punned pointer will break
3da827
    strict-aliasing rules [-Wstrict-aliasing]
3da827
        *(u_int16_t *)&sin6->sin6_addr.s6_addr[2] = 0;
3da827
    
3da827
    Signed-off-by: Steve Dickson <steved@redhat.com>
3da827
3da827
diff --git a/src/util.c b/src/util.c
3da827
index 9a5fb69..7d56479 100644
3da827
--- a/src/util.c
3da827
+++ b/src/util.c
3da827
@@ -101,12 +101,14 @@ static void
3da827
 in6_fillscopeid(struct sockaddr_in6 *sin6)
3da827
 {
3da827
 	u_int16_t ifindex;
3da827
+	u_int16_t *addr;
3da827
 
3da827
         if (IN6_IS_ADDR_LINKLOCAL(&sin6->sin6_addr)) {
3da827
-		ifindex = ntohs(*(u_int16_t *)&sin6->sin6_addr.s6_addr[2]);
3da827
+		addr = (u_int16_t *)&sin6->sin6_addr.s6_addr[2];
3da827
+		ifindex = ntohs(*addr);
3da827
 		if (sin6->sin6_scope_id == 0 && ifindex != 0) {
3da827
 			sin6->sin6_scope_id = ifindex;
3da827
-			*(u_int16_t *)&sin6->sin6_addr.s6_addr[2] = 0;
3da827
+			*addr = 0;
3da827
 		}
3da827
 	}
3da827
 }