netfilter/ipvs: use nla_put_u64_64bit()
authorNicolas Dichtel <nicolas.dichtel@6wind.com>
Mon, 25 Apr 2016 08:25:21 +0000 (10:25 +0200)
committerDavid S. Miller <davem@davemloft.net>
Mon, 25 Apr 2016 19:09:11 +0000 (15:09 -0400)
Signed-off-by: Nicolas Dichtel <nicolas.dichtel@6wind.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/uapi/linux/ip_vs.h
net/netfilter/ipvs/ip_vs_ctl.c

index 391395c06c7ea55d80fb64dfefc77b122b0a56d4..22d69894bc92ac63c6f96b7835ff9f1720f518e0 100644 (file)
@@ -435,6 +435,7 @@ enum {
        IPVS_STATS_ATTR_OUTPPS,         /* current out packet rate */
        IPVS_STATS_ATTR_INBPS,          /* current in byte rate */
        IPVS_STATS_ATTR_OUTBPS,         /* current out byte rate */
+       IPVS_STATS_ATTR_PAD,
        __IPVS_STATS_ATTR_MAX,
 };
 
index 404b2a4f4b5be90f630a20ff592e030f1ed4d671..f35ebc02fa5c4e9bf4de1bf0ec3dc0cb8f4ebe0b 100644 (file)
@@ -2875,8 +2875,10 @@ static int ip_vs_genl_fill_stats(struct sk_buff *skb, int container_type,
        if (nla_put_u32(skb, IPVS_STATS_ATTR_CONNS, (u32)kstats->conns) ||
            nla_put_u32(skb, IPVS_STATS_ATTR_INPKTS, (u32)kstats->inpkts) ||
            nla_put_u32(skb, IPVS_STATS_ATTR_OUTPKTS, (u32)kstats->outpkts) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_INBYTES, kstats->inbytes) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_OUTBYTES, kstats->outbytes) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_INBYTES, kstats->inbytes,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_OUTBYTES, kstats->outbytes,
+                             IPVS_STATS_ATTR_PAD) ||
            nla_put_u32(skb, IPVS_STATS_ATTR_CPS, (u32)kstats->cps) ||
            nla_put_u32(skb, IPVS_STATS_ATTR_INPPS, (u32)kstats->inpps) ||
            nla_put_u32(skb, IPVS_STATS_ATTR_OUTPPS, (u32)kstats->outpps) ||
@@ -2900,16 +2902,26 @@ static int ip_vs_genl_fill_stats64(struct sk_buff *skb, int container_type,
        if (!nl_stats)
                return -EMSGSIZE;
 
-       if (nla_put_u64(skb, IPVS_STATS_ATTR_CONNS, kstats->conns) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_INPKTS, kstats->inpkts) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_OUTPKTS, kstats->outpkts) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_INBYTES, kstats->inbytes) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_OUTBYTES, kstats->outbytes) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_CPS, kstats->cps) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_INPPS, kstats->inpps) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_OUTPPS, kstats->outpps) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_INBPS, kstats->inbps) ||
-           nla_put_u64(skb, IPVS_STATS_ATTR_OUTBPS, kstats->outbps))
+       if (nla_put_u64_64bit(skb, IPVS_STATS_ATTR_CONNS, kstats->conns,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_INPKTS, kstats->inpkts,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_OUTPKTS, kstats->outpkts,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_INBYTES, kstats->inbytes,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_OUTBYTES, kstats->outbytes,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_CPS, kstats->cps,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_INPPS, kstats->inpps,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_OUTPPS, kstats->outpps,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_INBPS, kstats->inbps,
+                             IPVS_STATS_ATTR_PAD) ||
+           nla_put_u64_64bit(skb, IPVS_STATS_ATTR_OUTBPS, kstats->outbps,
+                             IPVS_STATS_ATTR_PAD))
                goto nla_put_failure;
        nla_nest_end(skb, nl_stats);