[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4AE88907.3030206@hp.com>
Date: Wed, 28 Oct 2009 11:10:15 -0700
From: Rick Jones <rick.jones2@...com>
To: Steve Chen <schen@...sta.com>
CC: Mark Huth <mhuth@...sta.com>, netdev@...r.kernel.org
Subject: Re: [PATCH] Multicast packet reassembly can fail
>>If I understand correctly, the idea here is to say that when multiple interfaces
>>receive fragments of copies of the same IP datagram that both copies will
>>"survive" and flow up the stack?
>>
>>I'm basing that on your description, and an email from Steve that reads:
>>
>>
>>>Actually, the patch tries to prevent packet drop for this exact
>>>scenario. Please consider the following scenarios
>>>1. Packet comes in the fragment reassemble code in the following order
>>>(eth0 frag1), (eth0 frag2), (eth1 frag1), (eth1 frag2)
>>>Packet from both interfaces get reassembled and gets further processed.
>>>
>>>2. Packet can some times arrive in (perhaps other orders as well)
>>>(eth0 frag1), (eth1 frag1), (eth0 frag2), (eth1 frag2)
>>>Without this patch, eth0 frag 1/2 are overwritten by eth1 frag1/2, and
>>>packet from eth1 is dropped in the routing code.
>>
>>Doesn't that rather fly in the face of the weak-end-system model followed by Linux?
>>
>>I can see where scenario one leads to two IP datagrams making it up the stack,
>>but I would have thought that was simply an "accident" of the situation that
>>cannot reasonably be prevented, not justification to cause scenario two to send
>>two datagrams up the stack.
>
>
> For scenario 2, the routing code drops the 2nd packet. As a result, no
> packet make it to the application. If someone is willing to suggest an
> alternative, I can certainly rework the patch and retest.
I'll ask my next potentially Emily Litella question - don't multicast IP
applications bind to multicast IP addresses and not interfaces? That is to say,
doesn't the first datagram completed get delivered to all applications on the
host which have bound to the corresponding multicast IP (and port number...) ?
rick jones
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists