LVS
lvs-devel
Google
 
Web LinuxVirtualServer.org

[PATCH net-next 8/9] netfilter/ipvs: use nla_put_u64_64bit()

To: netdev@xxxxxxxxxxxxxxx
Subject: [PATCH net-next 8/9] netfilter/ipvs: use nla_put_u64_64bit()
Cc: davem@xxxxxxxxxxxxx, jhs@xxxxxxxxxxxx, stephen@xxxxxxxxxxxxxxxxxx, pshelar@xxxxxxxxxx, aar@xxxxxxxxxxxxxx, linux-wpan@xxxxxxxxxxxxxxx, wensong@xxxxxxxxxxxx, horms@xxxxxxxxxxxx, ja@xxxxxx, pablo@xxxxxxxxxxxxx, kaber@xxxxxxxxx, kadlec@xxxxxxxxxxxxxxxxx, lvs-devel@xxxxxxxxxxxxxxx, netfilter-devel@xxxxxxxxxxxxxxx, johannes@xxxxxxxxxxxxxxxx, linux-wireless@xxxxxxxxxxxxxxx, Nicolas Dichtel <nicolas.dichtel@xxxxxxxxx>
From: Nicolas Dichtel <nicolas.dichtel@xxxxxxxxx>
Date: Mon, 25 Apr 2016 10:25:21 +0200
Signed-off-by: Nicolas Dichtel <nicolas.dichtel@xxxxxxxxx>
---
 include/uapi/linux/ip_vs.h     |  1 +
 net/netfilter/ipvs/ip_vs_ctl.c | 36 ++++++++++++++++++++++++------------
 2 files changed, 25 insertions(+), 12 deletions(-)

diff --git a/include/uapi/linux/ip_vs.h b/include/uapi/linux/ip_vs.h
index 391395c06c7e..22d69894bc92 100644
--- a/include/uapi/linux/ip_vs.h
+++ b/include/uapi/linux/ip_vs.h
@@ -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,
 };
 
diff --git a/net/netfilter/ipvs/ip_vs_ctl.c b/net/netfilter/ipvs/ip_vs_ctl.c
index 404b2a4f4b5b..f35ebc02fa5c 100644
--- a/net/netfilter/ipvs/ip_vs_ctl.c
+++ b/net/netfilter/ipvs/ip_vs_ctl.c
@@ -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);
 
-- 
2.8.1

--
To unsubscribe from this list: send the line "unsubscribe lvs-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

<Prev in Thread] Current Thread [Next in Thread>