4.9-stable review patch.  If anyone has any objections, please let me know.

------------------

From: Jack Morgenstein <ja...@dev.mellanox.co.il>

commit befcabcd530e4ffb6f016638f693b7d94986d2ba upstream.

If OpenSM runs over a ConnectX-3, and there are ConnectX-4 or Connect-IB
VFs active on the network, the OpenSM will receive QP1 packets containing
a GRH where the destination GID is the "Well-Known GID" -- which is not a
GID in the HCA Port's GID Table.

This GID must be tested-for separately -- and packets which contain
this destination GID should be routed to slave 0 (the PF).

Fixes: 37bfc7c1e83f ('IB/mlx4: SR-IOV multiplex and demultiplex MADs')
Signed-off-by: Jack Morgenstein <ja...@dev.mellanox.co.il>
Signed-off-by: Daniel Jurgens <dani...@mellanox.com>
Signed-off-by: Leon Romanovsky <l...@kernel.org>
Signed-off-by: Doug Ledford <dledf...@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gre...@linuxfoundation.org>

---
 drivers/infiniband/hw/mlx4/mad.c |   16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)

--- a/drivers/infiniband/hw/mlx4/mad.c
+++ b/drivers/infiniband/hw/mlx4/mad.c
@@ -702,10 +702,18 @@ static int mlx4_ib_demux_mad(struct ib_d
 
        /* If a grh is present, we demux according to it */
        if (wc->wc_flags & IB_WC_GRH) {
-               slave = mlx4_ib_find_real_gid(ibdev, port, 
grh->dgid.global.interface_id);
-               if (slave < 0) {
-                       mlx4_ib_warn(ibdev, "failed matching grh\n");
-                       return -ENOENT;
+               if (grh->dgid.global.interface_id ==
+                       cpu_to_be64(IB_SA_WELL_KNOWN_GUID) &&
+                   grh->dgid.global.subnet_prefix == cpu_to_be64(
+                       atomic64_read(&dev->sriov.demux[port - 
1].subnet_prefix))) {
+                       slave = 0;
+               } else {
+                       slave = mlx4_ib_find_real_gid(ibdev, port,
+                                                     
grh->dgid.global.interface_id);
+                       if (slave < 0) {
+                               mlx4_ib_warn(ibdev, "failed matching grh\n");
+                               return -ENOENT;
+                       }
                }
        }
        /* Class-specific handling */


Reply via email to