[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <55363BBB.1020407@mellanox.com>
Date: Tue, 21 Apr 2015 14:59:55 +0300
From: Haggai Eran <haggaie@...lanox.com>
To: Jason Gunthorpe <jgunthorpe@...idianresearch.com>
CC: Doug Ledford <dledford@...hat.com>,
Roland Dreier <roland@...nel.org>,
Sean Hefty <sean.hefty@...el.com>,
<linux-rdma@...r.kernel.org>, <netdev@...r.kernel.org>,
Liran Liss <liranl@...lanox.com>,
Guy Shapiro <guysh@...lanox.com>,
Shachar Raindel <raindel@...lanox.com>,
Yotam Kenneth <yotamke@...lanox.com>
Subject: Re: [PATCH v2 07/11] IB/cm: Add network namespace support
On 20/04/2015 20:06, Jason Gunthorpe wrote:
> On Mon, Apr 20, 2015 at 12:03:38PM +0300, Haggai Eran wrote:
>> From: Guy Shapiro <guysh@...lanox.com>
>>
>> Add namespace support to the IB-CM layer.
>
>> - Each CM-ID now has a network namespace it is associated with, assigned at
>> creation. This namespace is used as needed during subsequent action on the
>> CM-ID or related objects.
>
> There is really something weird about this layering. At the CM layer
> there should be no concept of an IP address, it only deals with GIDs.
Using the GID alone is not enough to distinguish between namespaces,
because you can have multiple IPoIB interfaces, all using the GID (and
possibly the same P_Key), and each belonging to a different namespace.
> So how can a CM object have a network namespace associated with it?
The listener rbtree's key is currently the service ID, for instance. Now
with namespaces, you can have multiple listeners listening on the same
service ID, so we need to use (service ID, namespace) as the key.
>
>> {
>> av->port = port;
>> av->pkey_index = wc->pkey_index;
>> ib_init_ah_from_wc(port->cm_dev->ib_device, port->port_num, wc,
>> - grh, &av->ah_attr, &init_net);
>> + grh, &av->ah_attr, net);
>
> There is something deeply wrong with adding network namespace
> arguments to verbs.
>
> For rocee the gid index clearly specifies the network namespace
> to use, so much of this should go away and have rocee get the
> namespace from the gid index.
>
> Ie in ib_init_ah_from_wc we have the ib_wc which contains the sgid
> index.
I don't see it there. The code seem to fetch the GID from the GRH.
Because the IP address in the source GID can be the same for different
namespaces, this is not enough to pick the right namespace.
Regards,
Haggai
--
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