aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband/hw/mlx4/main.c
diff options
context:
space:
mode:
authorJack Morgenstein <jackm@dev.mellanox.co.il>2012-08-03 04:40:45 -0400
committerRoland Dreier <roland@purestorage.com>2012-09-30 23:33:34 -0400
commit0a9a01884d447c216eff75f8f274a0a3e82c7cee (patch)
treec25b38c66c4d26c71b82c65a558316eeb4419231 /drivers/infiniband/hw/mlx4/main.c
parent37bfc7c1e83f1589bcdc5918c7216422662644ee (diff)
mlx4: MAD_IFC paravirtualization
The MAD_IFC firmware command fulfills two functions. First, it is used in the QP0/QP1 MAD-handling flow to obtain information from the FW (for answering queries), and for setting variables in the HCA (MAD SET packets). For this, MAD_IFC should provide the FW (physical) view of the data. This is the view that OpenSM needs. We call this the "network view". In the second case, MAD_IFC is used by various verbs to obtain data regarding the local HCA (e.g., ib_query_device()). We call this the "host view". This data needs to be paravirtualized. MAD_IFC therefore needs a wrapper function, and also needs another flag indicating whether it should provide the network view (when it is called by ib_process_mad in special-qp packet handling), or the host view (when it is called while implementing a verb). There are currently 2 flag parameters in mlx4_MAD_IFC already: ignore_bkey and ignore_mkey. These two parameters are replaced by a single "mad_ifc_flags" parameter, with different bits set for each flag. A third flag is added: "network-view/host-view". Signed-off-by: Jack Morgenstein <jackm@dev.mellanox.co.il> Signed-off-by: Roland Dreier <roland@purestorage.com>
Diffstat (limited to 'drivers/infiniband/hw/mlx4/main.c')
-rw-r--r--drivers/infiniband/hw/mlx4/main.c64
1 files changed, 47 insertions, 17 deletions
diff --git a/drivers/infiniband/hw/mlx4/main.c b/drivers/infiniband/hw/mlx4/main.c
index 8e10ec2af7b6..45a6cc04036b 100644
--- a/drivers/infiniband/hw/mlx4/main.c
+++ b/drivers/infiniband/hw/mlx4/main.c
@@ -98,7 +98,8 @@ static int mlx4_ib_query_device(struct ib_device *ibdev,
98 init_query_mad(in_mad); 98 init_query_mad(in_mad);
99 in_mad->attr_id = IB_SMP_ATTR_NODE_INFO; 99 in_mad->attr_id = IB_SMP_ATTR_NODE_INFO;
100 100
101 err = mlx4_MAD_IFC(to_mdev(ibdev), 1, 1, 1, NULL, NULL, in_mad, out_mad); 101 err = mlx4_MAD_IFC(to_mdev(ibdev), MLX4_MAD_IFC_IGNORE_KEYS,
102 1, NULL, NULL, in_mad, out_mad);
102 if (err) 103 if (err)
103 goto out; 104 goto out;
104 105
@@ -182,11 +183,12 @@ mlx4_ib_port_link_layer(struct ib_device *device, u8 port_num)
182} 183}
183 184
184static int ib_link_query_port(struct ib_device *ibdev, u8 port, 185static int ib_link_query_port(struct ib_device *ibdev, u8 port,
185 struct ib_port_attr *props) 186 struct ib_port_attr *props, int netw_view)
186{ 187{
187 struct ib_smp *in_mad = NULL; 188 struct ib_smp *in_mad = NULL;
188 struct ib_smp *out_mad = NULL; 189 struct ib_smp *out_mad = NULL;
189 int ext_active_speed; 190 int ext_active_speed;
191 int mad_ifc_flags = MLX4_MAD_IFC_IGNORE_KEYS;
190 int err = -ENOMEM; 192 int err = -ENOMEM;
191 193
192 in_mad = kzalloc(sizeof *in_mad, GFP_KERNEL); 194 in_mad = kzalloc(sizeof *in_mad, GFP_KERNEL);
@@ -198,7 +200,10 @@ static int ib_link_query_port(struct ib_device *ibdev, u8 port,
198 in_mad->attr_id = IB_SMP_ATTR_PORT_INFO; 200 in_mad->attr_id = IB_SMP_ATTR_PORT_INFO;
199 in_mad->attr_mod = cpu_to_be32(port); 201 in_mad->attr_mod = cpu_to_be32(port);
200 202
201 err = mlx4_MAD_IFC(to_mdev(ibdev), 1, 1, port, NULL, NULL, 203 if (mlx4_is_mfunc(to_mdev(ibdev)->dev) && netw_view)
204 mad_ifc_flags |= MLX4_MAD_IFC_NET_VIEW;
205
206 err = mlx4_MAD_IFC(to_mdev(ibdev), mad_ifc_flags, port, NULL, NULL,
202 in_mad, out_mad); 207 in_mad, out_mad);
203 if (err) 208 if (err)
204 goto out; 209 goto out;
@@ -211,7 +216,10 @@ static int ib_link_query_port(struct ib_device *ibdev, u8 port,
211 props->state = out_mad->data[32] & 0xf; 216 props->state = out_mad->data[32] & 0xf;
212 props->phys_state = out_mad->data[33] >> 4; 217 props->phys_state = out_mad->data[33] >> 4;
213 props->port_cap_flags = be32_to_cpup((__be32 *) (out_mad->data + 20)); 218 props->port_cap_flags = be32_to_cpup((__be32 *) (out_mad->data + 20));
214 props->gid_tbl_len = to_mdev(ibdev)->dev->caps.gid_table_len[port]; 219 if (netw_view)
220 props->gid_tbl_len = out_mad->data[50];
221 else
222 props->gid_tbl_len = to_mdev(ibdev)->dev->caps.gid_table_len[port];
215 props->max_msg_sz = to_mdev(ibdev)->dev->caps.max_msg_sz; 223 props->max_msg_sz = to_mdev(ibdev)->dev->caps.max_msg_sz;
216 props->pkey_tbl_len = to_mdev(ibdev)->dev->caps.pkey_table_len[port]; 224 props->pkey_tbl_len = to_mdev(ibdev)->dev->caps.pkey_table_len[port];
217 props->bad_pkey_cntr = be16_to_cpup((__be16 *) (out_mad->data + 46)); 225 props->bad_pkey_cntr = be16_to_cpup((__be16 *) (out_mad->data + 46));
@@ -244,7 +252,7 @@ static int ib_link_query_port(struct ib_device *ibdev, u8 port,
244 in_mad->attr_id = MLX4_ATTR_EXTENDED_PORT_INFO; 252 in_mad->attr_id = MLX4_ATTR_EXTENDED_PORT_INFO;
245 in_mad->attr_mod = cpu_to_be32(port); 253 in_mad->attr_mod = cpu_to_be32(port);
246 254
247 err = mlx4_MAD_IFC(to_mdev(ibdev), 1, 1, port, 255 err = mlx4_MAD_IFC(to_mdev(ibdev), mad_ifc_flags, port,
248 NULL, NULL, in_mad, out_mad); 256 NULL, NULL, in_mad, out_mad);
249 if (err) 257 if (err)
250 goto out; 258 goto out;
@@ -270,7 +278,7 @@ static u8 state_to_phys_state(enum ib_port_state state)
270} 278}
271 279
272static int eth_link_query_port(struct ib_device *ibdev, u8 port, 280static int eth_link_query_port(struct ib_device *ibdev, u8 port,
273 struct ib_port_attr *props) 281 struct ib_port_attr *props, int netw_view)
274{ 282{
275 283
276 struct mlx4_ib_dev *mdev = to_mdev(ibdev); 284 struct mlx4_ib_dev *mdev = to_mdev(ibdev);
@@ -320,20 +328,27 @@ out:
320 return err; 328 return err;
321} 329}
322 330
323static int mlx4_ib_query_port(struct ib_device *ibdev, u8 port, 331int __mlx4_ib_query_port(struct ib_device *ibdev, u8 port,
324 struct ib_port_attr *props) 332 struct ib_port_attr *props, int netw_view)
325{ 333{
326 int err; 334 int err;
327 335
328 memset(props, 0, sizeof *props); 336 memset(props, 0, sizeof *props);
329 337
330 err = mlx4_ib_port_link_layer(ibdev, port) == IB_LINK_LAYER_INFINIBAND ? 338 err = mlx4_ib_port_link_layer(ibdev, port) == IB_LINK_LAYER_INFINIBAND ?
331 ib_link_query_port(ibdev, port, props) : 339 ib_link_query_port(ibdev, port, props, netw_view) :
332 eth_link_query_port(ibdev, port, props); 340 eth_link_query_port(ibdev, port, props, netw_view);
333 341
334 return err; 342 return err;
335} 343}
336 344
345static int mlx4_ib_query_port(struct ib_device *ibdev, u8 port,
346 struct ib_port_attr *props)
347{
348 /* returns host view */
349 return __mlx4_ib_query_port(ibdev, port, props, 0);
350}
351
337static int __mlx4_ib_query_gid(struct ib_device *ibdev, u8 port, int index, 352static int __mlx4_ib_query_gid(struct ib_device *ibdev, u8 port, int index,
338 union ib_gid *gid) 353 union ib_gid *gid)
339{ 354{
@@ -350,7 +365,8 @@ static int __mlx4_ib_query_gid(struct ib_device *ibdev, u8 port, int index,
350 in_mad->attr_id = IB_SMP_ATTR_PORT_INFO; 365 in_mad->attr_id = IB_SMP_ATTR_PORT_INFO;
351 in_mad->attr_mod = cpu_to_be32(port); 366 in_mad->attr_mod = cpu_to_be32(port);
352 367
353 err = mlx4_MAD_IFC(to_mdev(ibdev), 1, 1, port, NULL, NULL, in_mad, out_mad); 368 err = mlx4_MAD_IFC(to_mdev(ibdev), MLX4_MAD_IFC_IGNORE_KEYS, port,
369 NULL, NULL, in_mad, out_mad);
354 if (err) 370 if (err)
355 goto out; 371 goto out;
356 372
@@ -360,7 +376,8 @@ static int __mlx4_ib_query_gid(struct ib_device *ibdev, u8 port, int index,
360 in_mad->attr_id = IB_SMP_ATTR_GUID_INFO; 376 in_mad->attr_id = IB_SMP_ATTR_GUID_INFO;
361 in_mad->attr_mod = cpu_to_be32(index / 8); 377 in_mad->attr_mod = cpu_to_be32(index / 8);
362 378
363 err = mlx4_MAD_IFC(to_mdev(ibdev), 1, 1, port, NULL, NULL, in_mad, out_mad); 379 err = mlx4_MAD_IFC(to_mdev(ibdev), MLX4_MAD_IFC_IGNORE_KEYS, port,
380 NULL, NULL, in_mad, out_mad);
364 if (err) 381 if (err)
365 goto out; 382 goto out;
366 383
@@ -391,11 +408,12 @@ static int mlx4_ib_query_gid(struct ib_device *ibdev, u8 port, int index,
391 return iboe_query_gid(ibdev, port, index, gid); 408 return iboe_query_gid(ibdev, port, index, gid);
392} 409}
393 410
394static int mlx4_ib_query_pkey(struct ib_device *ibdev, u8 port, u16 index, 411int __mlx4_ib_query_pkey(struct ib_device *ibdev, u8 port, u16 index,
395 u16 *pkey) 412 u16 *pkey, int netw_view)
396{ 413{
397 struct ib_smp *in_mad = NULL; 414 struct ib_smp *in_mad = NULL;
398 struct ib_smp *out_mad = NULL; 415 struct ib_smp *out_mad = NULL;
416 int mad_ifc_flags = MLX4_MAD_IFC_IGNORE_KEYS;
399 int err = -ENOMEM; 417 int err = -ENOMEM;
400 418
401 in_mad = kzalloc(sizeof *in_mad, GFP_KERNEL); 419 in_mad = kzalloc(sizeof *in_mad, GFP_KERNEL);
@@ -407,7 +425,11 @@ static int mlx4_ib_query_pkey(struct ib_device *ibdev, u8 port, u16 index,
407 in_mad->attr_id = IB_SMP_ATTR_PKEY_TABLE; 425 in_mad->attr_id = IB_SMP_ATTR_PKEY_TABLE;
408 in_mad->attr_mod = cpu_to_be32(index / 32); 426 in_mad->attr_mod = cpu_to_be32(index / 32);
409 427
410 err = mlx4_MAD_IFC(to_mdev(ibdev), 1, 1, port, NULL, NULL, in_mad, out_mad); 428 if (mlx4_is_mfunc(to_mdev(ibdev)->dev) && netw_view)
429 mad_ifc_flags |= MLX4_MAD_IFC_NET_VIEW;
430
431 err = mlx4_MAD_IFC(to_mdev(ibdev), mad_ifc_flags, port, NULL, NULL,
432 in_mad, out_mad);
411 if (err) 433 if (err)
412 goto out; 434 goto out;
413 435
@@ -419,6 +441,11 @@ out:
419 return err; 441 return err;
420} 442}
421 443
444static int mlx4_ib_query_pkey(struct ib_device *ibdev, u8 port, u16 index, u16 *pkey)
445{
446 return __mlx4_ib_query_pkey(ibdev, port, index, pkey, 0);
447}
448
422static int mlx4_ib_modify_device(struct ib_device *ibdev, int mask, 449static int mlx4_ib_modify_device(struct ib_device *ibdev, int mask,
423 struct ib_device_modify *props) 450 struct ib_device_modify *props)
424{ 451{
@@ -849,6 +876,7 @@ static int init_node_data(struct mlx4_ib_dev *dev)
849{ 876{
850 struct ib_smp *in_mad = NULL; 877 struct ib_smp *in_mad = NULL;
851 struct ib_smp *out_mad = NULL; 878 struct ib_smp *out_mad = NULL;
879 int mad_ifc_flags = MLX4_MAD_IFC_IGNORE_KEYS;
852 int err = -ENOMEM; 880 int err = -ENOMEM;
853 881
854 in_mad = kzalloc(sizeof *in_mad, GFP_KERNEL); 882 in_mad = kzalloc(sizeof *in_mad, GFP_KERNEL);
@@ -858,8 +886,10 @@ static int init_node_data(struct mlx4_ib_dev *dev)
858 886
859 init_query_mad(in_mad); 887 init_query_mad(in_mad);
860 in_mad->attr_id = IB_SMP_ATTR_NODE_DESC; 888 in_mad->attr_id = IB_SMP_ATTR_NODE_DESC;
889 if (mlx4_is_master(dev->dev))
890 mad_ifc_flags |= MLX4_MAD_IFC_NET_VIEW;
861 891
862 err = mlx4_MAD_IFC(dev, 1, 1, 1, NULL, NULL, in_mad, out_mad); 892 err = mlx4_MAD_IFC(dev, mad_ifc_flags, 1, NULL, NULL, in_mad, out_mad);
863 if (err) 893 if (err)
864 goto out; 894 goto out;
865 895
@@ -867,7 +897,7 @@ static int init_node_data(struct mlx4_ib_dev *dev)
867 897
868 in_mad->attr_id = IB_SMP_ATTR_NODE_INFO; 898 in_mad->attr_id = IB_SMP_ATTR_NODE_INFO;
869 899
870 err = mlx4_MAD_IFC(dev, 1, 1, 1, NULL, NULL, in_mad, out_mad); 900 err = mlx4_MAD_IFC(dev, mad_ifc_flags, 1, NULL, NULL, in_mad, out_mad);
871 if (err) 901 if (err)
872 goto out; 902 goto out;
873 903