aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband
diff options
context:
space:
mode:
authorJack Morgenstein <jackm@dev.mellanox.co.il>2012-06-19 04:21:44 -0400
committerRoland Dreier <roland@purestorage.com>2012-07-11 14:52:23 -0400
commit6634961c14d38ef64ec284c07aecb03d3dd03b4a (patch)
treea91bc4fa44848799c3035a9bfea1b288c2edac82 /drivers/infiniband
parent105c320f6ac37af30252577d419e47b39edb5843 (diff)
mlx4: Put physical GID and P_Key table sizes in mlx4_phys_caps struct and paravirtualize them
To allow easy paravirtualization of P_Key and GID table sizes, keep paravirtualized sizes in mlx4_dev->caps, but save the actual physical sizes from FW in struct: mlx4_dev->phys_cap. In addition, in SR-IOV mode, do the following: 1. Reduce reported P_Key table size by 1. This is done to reserve the highest P_Key index for internal use, for declaring an invalid P_Key in P_Key paravirtualization. We require a P_Key index which always contain an invalid P_Key value for this purpose (i.e., one which cannot be modified by the subnet manager). The way to do this is to reduce the P_Key table size reported to the subnet manager by 1, so that it will not attempt to access the P_Key at index #127. 2. Paravirtualize the GID table size to 1. Thus, each guest sees only a single GID (at its paravirtualized index 0). In addition, since we are paravirtualizing the GID table size to 1, we add paravirtualization of the master GID event here (i.e., we do not do ib_dispatch_event() for the GUID change event on the master, since its (only) GUID never changes). Signed-off-by: Jack Morgenstein <jackm@dev.mellanox.co.il> Signed-off-by: Roland Dreier <roland@purestorage.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r--drivers/infiniband/hw/mlx4/mad.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/drivers/infiniband/hw/mlx4/mad.c b/drivers/infiniband/hw/mlx4/mad.c
index 58c45fb5bd31..c27141fef1ab 100644
--- a/drivers/infiniband/hw/mlx4/mad.c
+++ b/drivers/infiniband/hw/mlx4/mad.c
@@ -184,8 +184,10 @@ static void smp_snoop(struct ib_device *ibdev, u8 port_num, struct ib_mad *mad,
184 break; 184 break;
185 185
186 case IB_SMP_ATTR_GUID_INFO: 186 case IB_SMP_ATTR_GUID_INFO:
187 mlx4_ib_dispatch_event(dev, port_num, 187 /* paravirtualized master's guid is guid 0 -- does not change */
188 IB_EVENT_GID_CHANGE); 188 if (!mlx4_is_master(dev->dev))
189 mlx4_ib_dispatch_event(dev, port_num,
190 IB_EVENT_GID_CHANGE);
189 break; 191 break;
190 default: 192 default:
191 break; 193 break;
@@ -487,7 +489,9 @@ void handle_port_mgmt_change_event(struct work_struct *work)
487 mlx4_ib_dispatch_event(dev, port, IB_EVENT_PKEY_CHANGE); 489 mlx4_ib_dispatch_event(dev, port, IB_EVENT_PKEY_CHANGE);
488 break; 490 break;
489 case MLX4_DEV_PMC_SUBTYPE_GUID_INFO: 491 case MLX4_DEV_PMC_SUBTYPE_GUID_INFO:
490 mlx4_ib_dispatch_event(dev, port, IB_EVENT_GID_CHANGE); 492 /* paravirtualized master's guid is guid 0 -- does not change */
493 if (!mlx4_is_master(dev->dev))
494 mlx4_ib_dispatch_event(dev, port, IB_EVENT_GID_CHANGE);
491 break; 495 break;
492 default: 496 default:
493 pr_warn("Unsupported subtype 0x%x for " 497 pr_warn("Unsupported subtype 0x%x for "