<html><body>
<p><tt>Roland Dreier <rdreier@cisco.com> wrote on 03/06/2007 12:20:55 PM:<br>
> > I believe even IPv6 with ethernet, the interface will be UP and RUNNING<br>
> > even they have a duplicated IPv6 address so IPv4 can work. I don't know why<br>
> > we do thing differently here.<br>
> <br>
> That's not the point. The point is that if we bring the interface up<br>
> before the multicast groups are joined, then IPv6 DAD has a chance of<br>
> incorrectly not detecting duplicate addresses (think about it -- if<br>
> IPv6 autoconf/DAD starts before all the multicast groups are ready,<br>
> then the IPv6 stack will generate ND and router solicitation messages,<br>
> but they will just be queued up pending multicast join completion, and<br>
> if that doesn't happen before the timeouts occur, then the IPv6 stack<br>
> will incorrectly conclude that a duplicate address doesn't exist, even<br>
> if it does)</tt><br>
<tt>The IPv6 stack will generate ND and router solicitation messages when sending packet. The duplicated address can be detected anytime. Am I right? So if the multicast join completion later, the duplication address will be detect later.</tt><br>
<tt><br>
I thought none of the packets can be sent out before the interface is up and running. The link carrier is ON, doesn't mean packets can be sent, it only means the carrier is ready to send data. I looked at the code again, and found that the interface is UP in the beginning of the ipoib code. We could move the UP in the end of operation.</tt><br>
<tt><br>
> The real question is what tradeoff do we want to make for broken<br>
> fabrics where some multicast groups can never be joined. Is it worth<br>
> the (small) risk of breaking IPv6 autoconf on good fabrics in order to<br>
> behave more gracefully on broken fabrics?<br>
> <br>
> - R.<br>
</tt><br>
<tt>My point is IPoIB should behave as other networking device drivers.</tt><br>
<br>
Thanks<br>
Shirley Ma</body></html>