From: yuan linyu <linyu.y...@alcatel-sbell.com.cn>

Signed-off-by: yuan linyu <linyu.y...@alcatel-sbell.com.cn>
---
 net/ipv6/mcast.c |  3 +--
 net/ipv6/ndisc.c | 13 ++-----------
 2 files changed, 3 insertions(+), 13 deletions(-)

diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c
index 07403fa..b186c67 100644
--- a/net/ipv6/mcast.c
+++ b/net/ipv6/mcast.c
@@ -2008,8 +2008,7 @@ static void igmp6_send(struct in6_addr *addr, struct 
net_device *dev, int type)
 
        memcpy(skb_put(skb, sizeof(ra)), ra, sizeof(ra));
 
-       hdr = (struct mld_msg *) skb_put(skb, sizeof(struct mld_msg));
-       memset(hdr, 0, sizeof(struct mld_msg));
+       hdr = (struct mld_msg *) skb_put_zero(skb, sizeof(struct mld_msg));
        hdr->mld_type = type;
        hdr->mld_mca = *addr;
 
diff --git a/net/ipv6/ndisc.c b/net/ipv6/ndisc.c
index d310dc4..e6586ed 100644
--- a/net/ipv6/ndisc.c
+++ b/net/ipv6/ndisc.c
@@ -144,21 +144,12 @@ void __ndisc_fill_addr_option(struct sk_buff *skb, int 
type, void *data,
                              int data_len, int pad)
 {
        int space = __ndisc_opt_addr_space(data_len, pad);
-       u8 *opt = skb_put(skb, space);
+       u8 *opt = skb_put_zero(skb, space);
 
        opt[0] = type;
        opt[1] = space>>3;
 
-       memset(opt + 2, 0, pad);
-       opt   += pad;
-       space -= pad;
-
-       memcpy(opt+2, data, data_len);
-       data_len += 2;
-       opt += data_len;
-       space -= data_len;
-       if (space > 0)
-               memset(opt, 0, space);
+       memcpy(opt+2+pad, data, data_len);
 }
 EXPORT_SYMBOL_GPL(__ndisc_fill_addr_option);
 
-- 
2.7.4


Reply via email to