Lines Matching defs:ibdev

144 static union ib_gid gid_from_req_msg(struct ib_device *ibdev, struct ib_mad *mad)
153 id_map_find_by_sl_id(struct ib_device *ibdev, u32 slave_id, u32 sl_cm_id)
155 struct rb_root *sl_id_map = &to_mdev(ibdev)->sriov.sl_id_map;
198 static void sl_id_map_add(struct ib_device *ibdev, struct id_map_entry *new)
200 struct rb_root *sl_id_map = &to_mdev(ibdev)->sriov.sl_id_map;
206 ent = id_map_find_by_sl_id(ibdev, slave_id, sl_cm_id);
231 id_map_alloc(struct ib_device *ibdev, int slave_id, u32 sl_cm_id)
235 struct mlx4_ib_sriov *sriov = &to_mdev(ibdev)->sriov;
244 ent->dev = to_mdev(ibdev);
251 sl_id_map_add(ibdev, ent);
259 mlx4_ib_warn(ibdev, "Allocation failed (err:0x%x)\n", ret);
264 id_map_get(struct ib_device *ibdev, int *pv_cm_id, int slave_id, int sl_cm_id)
267 struct mlx4_ib_sriov *sriov = &to_mdev(ibdev)->sriov;
271 ent = id_map_find_by_sl_id(ibdev, slave_id, sl_cm_id);
281 static void schedule_delayed(struct ib_device *ibdev, struct id_map_entry *id)
283 struct mlx4_ib_sriov *sriov = &to_mdev(ibdev)->sriov;
301 int mlx4_ib_multiplex_cm_handler(struct ib_device *ibdev, int port, int slave_id,
314 id = id_map_get(ibdev, &pv_cm_id, slave_id, sl_cm_id);
317 id = id_map_alloc(ibdev, slave_id, sl_cm_id);
319 mlx4_ib_warn(ibdev, "%s: id{slave: %d, sl_cm_id: 0x%x} Failed to id_map_alloc\n",
328 id = id_map_get(ibdev, &pv_cm_id, slave_id, sl_cm_id);
341 schedule_delayed(ibdev, id);
425 int mlx4_ib_demux_cm_handler(struct ib_device *ibdev, int port, int *slave,
428 struct mlx4_ib_sriov *sriov = &to_mdev(ibdev)->sriov;
441 gid = gid_from_req_msg(ibdev, mad);
442 *slave = mlx4_ib_find_real_gid(ibdev, port, gid.global.interface_id);
444 mlx4_ib_warn(ibdev, "failed matching slave_id by gid (0x%llx)\n",
459 id = id_map_get(ibdev, (int *)&pv_cm_id, -1, -1);
479 schedule_delayed(ibdev, id);