]> git.itanic.dy.fi Git - linux-stable/commitdiff
RDMA/cma: Do not ignore net namespace for unbound cm_id
authorParav Pandit <parav@mellanox.com>
Mon, 16 Jul 2018 08:50:13 +0000 (11:50 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 19 Sep 2018 20:48:59 +0000 (22:48 +0200)
[ Upstream commit 643d213a9a034fa04f5575a40dfc8548e33ce04f ]

Currently if the cm_id is not bound to any netdevice, than for such cm_id,
net namespace is ignored; which is incorrect.

Regardless of cm_id bound to a netdevice or not, net namespace must
match. When a cm_id is bound to a netdevice, in such case net namespace
and netdevice both must match.

Fixes: 4c21b5bcef73 ("IB/cma: Add net_dev and private data checks to RDMA CM")
Signed-off-by: Parav Pandit <parav@mellanox.com>
Reviewed-by: Daniel Jurgens <danielj@mellanox.com>
Signed-off-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Signed-off-by: Sasha Levin <alexander.levin@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/infiniband/core/cma.c

index d57a78ec74251ddbeb2ee134265e39cbd410b415..0f42411d6a79db441e4f4b933bb753b91d9d852c 100644 (file)
@@ -1280,9 +1280,16 @@ static bool cma_match_net_dev(const struct rdma_cm_id *id,
                       (addr->src_addr.ss_family == AF_IB ||
                        cma_protocol_roce_dev_port(id->device, port_num));
 
-       return !addr->dev_addr.bound_dev_if ||
-              (net_eq(dev_net(net_dev), addr->dev_addr.net) &&
-               addr->dev_addr.bound_dev_if == net_dev->ifindex);
+       /*
+        * Net namespaces must match, and if the listner is listening
+        * on a specific netdevice than netdevice must match as well.
+        */
+       if (net_eq(dev_net(net_dev), addr->dev_addr.net) &&
+           (!!addr->dev_addr.bound_dev_if ==
+            (addr->dev_addr.bound_dev_if == net_dev->ifindex)))
+               return true;
+       else
+               return false;
 }
 
 static struct rdma_id_private *cma_find_listener(