From: Wang Chen <wangchen@cn.fujitsu.com>
To: Patrick McHardy <kaber@trash.net>
Cc: "David S. Miller" <davem@davemloft.net>, NETDEV <netdev@vger.kernel.org>
Subject: Re: v3 [PATCH net-next 5/7] ipv4: Check return of dev_set_allmulti
Date: Mon, 14 Jul 2008 09:14:24 +0800 [thread overview]
Message-ID: <487AA870.30309@cn.fujitsu.com> (raw)
In-Reply-To: <487334B9.4040600@cn.fujitsu.com>
Wang Chen said the following on 2008-7-8 17:34:
> Patrick McHardy said the following on 2008-7-7 19:22:
>> Wang Chen wrote:
>>> case VIFF_TUNNEL:
>>> dev = ipmr_new_tunnel(vifc);
>>> if (!dev)
>>> return -ENOBUFS;
>>> + err = dev_set_allmulti(dev, 1);
>>> + if (err) {
>>> + dev_close(dev);
>>> + return err;
>>> + }
>> ipmr_new_tunnel creates a new tunnel device that you're not removing.
>>
>
> OK. Remove the created tunnel.
>
> Signed-off-by: Wang Chen <wangchen@cn.fujitsu.com>
> ---
> diff --git a/net/ipv4/ipmr.c b/net/ipv4/ipmr.c
> index 11700a4..a55a23a 100644
> --- a/net/ipv4/ipmr.c
> +++ b/net/ipv4/ipmr.c
> @@ -120,6 +120,31 @@ static struct timer_list ipmr_expire_timer;
>
> /* Service routines creating virtual interfaces: DVMRP tunnels and PIMREG */
>
> +static void ipmr_del_tunnel(struct net_device *dev, struct vifctl *v)
> +{
> + dev_close(dev);
> +
> + dev = __dev_get_by_name(&init_net, "tunl0");
> + if (dev) {
> + struct ifreq ifr;
> + mm_segment_t oldfs;
> + struct ip_tunnel_parm p;
> +
> + memset(&p, 0, sizeof(p));
> + p.iph.daddr = v->vifc_rmt_addr.s_addr;
> + p.iph.saddr = v->vifc_lcl_addr.s_addr;
> + p.iph.version = 4;
> + p.iph.ihl = 5;
> + p.iph.protocol = IPPROTO_IPIP;
> + sprintf(p.name, "dvmrp%d", v->vifc_vifi);
> + ifr.ifr_ifru.ifru_data = (__force void __user *)&p;
> +
> + oldfs = get_fs(); set_fs(KERNEL_DS);
> + dev->do_ioctl(dev, &ifr, SIOCDELTUNNEL);
> + set_fs(oldfs);
> + }
> +}
> +
> static
> struct net_device *ipmr_new_tunnel(struct vifctl *v)
> {
> @@ -398,6 +423,7 @@ static int vif_add(struct vifctl *vifc, int mrtsock)
> struct vif_device *v = &vif_table[vifi];
> struct net_device *dev;
> struct in_device *in_dev;
> + int err;
>
> /* Is vif busy ? */
> if (VIF_EXISTS(vifi))
> @@ -415,18 +441,31 @@ static int vif_add(struct vifctl *vifc, int mrtsock)
> dev = ipmr_reg_vif();
> if (!dev)
> return -ENOBUFS;
> + err = dev_set_allmulti(dev, 1);
> + if (err) {
> + unregister_netdevice(dev);
> + return err;
> + }
> break;
> #endif
> case VIFF_TUNNEL:
> dev = ipmr_new_tunnel(vifc);
> if (!dev)
> return -ENOBUFS;
> + err = dev_set_allmulti(dev, 1);
> + if (err) {
> + ipmr_del_tunnel(dev, vifc);
> + return err;
> + }
> break;
> case 0:
> dev = ip_dev_find(&init_net, vifc->vifc_lcl_addr.s_addr);
> if (!dev)
> return -EADDRNOTAVAIL;
> dev_put(dev);
> + err = dev_set_allmulti(dev, 1);
> + if (err)
> + return err;
> break;
> default:
> return -EINVAL;
> @@ -435,7 +474,6 @@ static int vif_add(struct vifctl *vifc, int mrtsock)
> if ((in_dev = __in_dev_get_rtnl(dev)) == NULL)
> return -EADDRNOTAVAIL;
> IPV4_DEVCONF(in_dev->cnf, MC_FORWARDING)++;
> - dev_set_allmulti(dev, +1);
> ip_rt_multicast_event(in_dev);
>
> /*
>
>
Patrick, would you please review this patch.
If you ack, I will resend whole series of patch to David again.
next prev parent reply other threads:[~2008-07-14 1:19 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-07-07 2:31 v3 [PATCH net-next 0/7] Check return of dev_set_promiscuity/allmulti Wang Chen
2008-07-07 2:33 ` v3 [PATCH net-next 1/7] af_packet: " Wang Chen
2008-07-07 2:34 ` v3 [PATCH net-next 2/7] bonding: " Wang Chen
2008-07-07 2:35 ` v3 [PATCH net-next 3/7] bridge: Check return of dev_set_promiscuity Wang Chen
2008-07-07 2:36 ` v3 [PATCH net-next 4/7] ipv6: Check return of dev_set_allmulti Wang Chen
2008-07-07 11:20 ` Patrick McHardy
2008-07-07 13:17 ` Wang Chen
2008-07-07 13:26 ` Patrick McHardy
2008-07-07 14:45 ` Wang Chen
2008-07-07 2:37 ` v3 [PATCH net-next 5/7] ipv4: " Wang Chen
2008-07-07 11:22 ` Patrick McHardy
2008-07-08 9:34 ` Wang Chen
2008-07-14 1:14 ` Wang Chen [this message]
2008-07-08 9:41 ` Wang Chen
2008-07-14 1:05 ` Wang Chen
2008-07-07 2:38 ` v3 [PATCH net-next 6/7] macvlan: " Wang Chen
2008-07-07 2:38 ` v3 [PATCH net-next 7/7] 8021q: Check return of dev_set_promiscuity/allmulti Wang Chen
-- strict thread matches above, loose matches on Subject: below --
2008-07-01 3:19 [PATCH net-next 0/7] " Wang Chen
2008-07-01 3:27 ` v2 [PATCH net-next 5/7] ipv4: Check return of dev_set_allmulti Wang Chen
2008-07-01 9:40 ` Patrick McHardy
2008-07-02 8:24 ` v3 " Wang Chen
2008-07-02 12:55 ` Patrick McHardy
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=487AA870.30309@cn.fujitsu.com \
--to=wangchen@cn.fujitsu.com \
--cc=davem@davemloft.net \
--cc=kaber@trash.net \
--cc=netdev@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.