Author: ae
Date: Thu Apr 19 10:11:39 2018
New Revision: 332765
URL: https://svnweb.freebsd.org/changeset/base/332765

Log:
  MFC r316825:
    Use address of specific union member instead of whole union address to
    fix PVS-Studio warnings.
  
  MFC r316826:
    Avoid undefined behavior.
  
    The 'pktid' variable is modified while being used twice between
    sequence points, probably due to htonl() is macro.

Modified:
  stable/11/sys/netpfil/ipfw/ip_fw_table_algo.c
  stable/11/sys/netpfil/ipfw/nat64/nat64stl.c
Directory Properties:
  stable/11/   (props changed)

Modified: stable/11/sys/netpfil/ipfw/ip_fw_table_algo.c
==============================================================================
--- stable/11/sys/netpfil/ipfw/ip_fw_table_algo.c       Thu Apr 19 10:08:28 
2018        (r332764)
+++ stable/11/sys/netpfil/ipfw/ip_fw_table_algo.c       Thu Apr 19 10:11:39 
2018        (r332765)
@@ -526,7 +526,8 @@ ta_dump_radix_tentry(void *ta_state, struct table_info
 #ifdef INET6
        } else {
                xn = (struct radix_addr_xentry *)e;
-               memcpy(&tent->k, &xn->addr6.sin6_addr, sizeof(struct in6_addr));
+               memcpy(&tent->k.addr6, &xn->addr6.sin6_addr,
+                   sizeof(struct in6_addr));
                tent->masklen = xn->masklen;
                tent->subtype = AF_INET6;
                tent->v.kidx = xn->value;
@@ -1381,7 +1382,7 @@ ta_dump_chash_tentry(void *ta_state, struct table_info
                tent->v.kidx = ent->value;
 #ifdef INET6
        } else {
-               memcpy(&tent->k, &ent->a.a6, sizeof(struct in6_addr));
+               memcpy(&tent->k.addr6, &ent->a.a6, sizeof(struct in6_addr));
                tent->masklen = cfg->mask6;
                tent->subtype = AF_INET6;
                tent->v.kidx = ent->value;
@@ -3984,7 +3985,8 @@ ta_dump_kfib_tentry_int(struct sockaddr *paddr, struct
        if (paddr->sa_family == AF_INET6) {
                addr6 = (struct sockaddr_in6 *)paddr;
                mask6 = (struct sockaddr_in6 *)pmask;
-               memcpy(&tent->k, &addr6->sin6_addr, sizeof(struct in6_addr));
+               memcpy(&tent->k.addr6, &addr6->sin6_addr,
+                   sizeof(struct in6_addr));
                len = 128;
                if (mask6 != NULL)
                        len = contigmask((uint8_t *)&mask6->sin6_addr, 128);

Modified: stable/11/sys/netpfil/ipfw/nat64/nat64stl.c
==============================================================================
--- stable/11/sys/netpfil/ipfw/nat64/nat64stl.c Thu Apr 19 10:08:28 2018        
(r332764)
+++ stable/11/sys/netpfil/ipfw/nat64/nat64stl.c Thu Apr 19 10:11:39 2018        
(r332765)
@@ -75,7 +75,8 @@ nat64stl_log(struct pfloghdr *plog, struct mbuf *m, sa
        plog->action = PF_NAT;
        plog->dir = PF_IN;
        plog->rulenr = htonl(kidx);
-       plog->subrulenr = htonl(++pktid);
+       pktid++;
+       plog->subrulenr = htonl(pktid);
        plog->ruleset[0] = '\0';
        strlcpy(plog->ifname, "NAT64STL", sizeof(plog->ifname));
        ipfw_bpf_mtap2(plog, PFLOG_HDRLEN, m);
_______________________________________________
svn-src-all@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to