Skip to content

Commit 7c2f769

Browse files
Leon Romanovskygregkh
authored andcommitted
RDMA: Change XRCD destroy return value
[ Upstream commit d0c45c8 ] Update XRCD destroy flow to allow command failure. Fixes: 28ad5f6 ("RDMA: Move XRCD to be under ib_core responsibility") Link: https://lore.kernel.org/r/20200907120921.476363-8-leon@kernel.org Signed-off-by: Leon Romanovsky <leonro@mellanox.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent 093f87d commit 7c2f769

5 files changed

Lines changed: 12 additions & 7 deletions

File tree

drivers/infiniband/core/verbs.c

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2333,13 +2333,17 @@ EXPORT_SYMBOL(ib_alloc_xrcd_user);
23332333
*/
23342334
int ib_dealloc_xrcd_user(struct ib_xrcd *xrcd, struct ib_udata *udata)
23352335
{
2336+
int ret;
2337+
23362338
if (atomic_read(&xrcd->usecnt))
23372339
return -EBUSY;
23382340

23392341
WARN_ON(!xa_empty(&xrcd->tgt_qps));
2340-
xrcd->device->ops.dealloc_xrcd(xrcd, udata);
2342+
ret = xrcd->device->ops.dealloc_xrcd(xrcd, udata);
2343+
if (ret)
2344+
return ret;
23412345
kfree(xrcd);
2342-
return 0;
2346+
return ret;
23432347
}
23442348
EXPORT_SYMBOL(ib_dealloc_xrcd_user);
23452349

drivers/infiniband/hw/mlx4/main.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1256,11 +1256,12 @@ static int mlx4_ib_alloc_xrcd(struct ib_xrcd *ibxrcd, struct ib_udata *udata)
12561256
return err;
12571257
}
12581258

1259-
static void mlx4_ib_dealloc_xrcd(struct ib_xrcd *xrcd, struct ib_udata *udata)
1259+
static int mlx4_ib_dealloc_xrcd(struct ib_xrcd *xrcd, struct ib_udata *udata)
12601260
{
12611261
ib_destroy_cq(to_mxrcd(xrcd)->cq);
12621262
ib_dealloc_pd(to_mxrcd(xrcd)->pd);
12631263
mlx4_xrcd_free(to_mdev(xrcd->device)->dev, to_mxrcd(xrcd)->xrcdn);
1264+
return 0;
12641265
}
12651266

12661267
static int add_gid_entry(struct ib_qp *ibqp, union ib_gid *gid)

drivers/infiniband/hw/mlx5/mlx5_ib.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1193,7 +1193,7 @@ int mlx5_ib_process_mad(struct ib_device *ibdev, int mad_flags, u8 port_num,
11931193
const struct ib_mad *in, struct ib_mad *out,
11941194
size_t *out_mad_size, u16 *out_mad_pkey_index);
11951195
int mlx5_ib_alloc_xrcd(struct ib_xrcd *xrcd, struct ib_udata *udata);
1196-
void mlx5_ib_dealloc_xrcd(struct ib_xrcd *xrcd, struct ib_udata *udata);
1196+
int mlx5_ib_dealloc_xrcd(struct ib_xrcd *xrcd, struct ib_udata *udata);
11971197
int mlx5_ib_get_buf_offset(u64 addr, int page_shift, u32 *offset);
11981198
int mlx5_query_ext_port_caps(struct mlx5_ib_dev *dev, u8 port);
11991199
int mlx5_query_mad_ifc_smp_attr_node_info(struct ib_device *ibdev,

drivers/infiniband/hw/mlx5/qp.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -4716,12 +4716,12 @@ int mlx5_ib_alloc_xrcd(struct ib_xrcd *ibxrcd, struct ib_udata *udata)
47164716
return mlx5_cmd_xrcd_alloc(dev->mdev, &xrcd->xrcdn, 0);
47174717
}
47184718

4719-
void mlx5_ib_dealloc_xrcd(struct ib_xrcd *xrcd, struct ib_udata *udata)
4719+
int mlx5_ib_dealloc_xrcd(struct ib_xrcd *xrcd, struct ib_udata *udata)
47204720
{
47214721
struct mlx5_ib_dev *dev = to_mdev(xrcd->device);
47224722
u32 xrcdn = to_mxrcd(xrcd)->xrcdn;
47234723

4724-
mlx5_cmd_xrcd_dealloc(dev->mdev, xrcdn, 0);
4724+
return mlx5_cmd_xrcd_dealloc(dev->mdev, xrcdn, 0);
47254725
}
47264726

47274727
static void mlx5_ib_wq_event(struct mlx5_core_qp *core_qp, int type)

include/rdma/ib_verbs.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2468,7 +2468,7 @@ struct ib_device_ops {
24682468
int (*attach_mcast)(struct ib_qp *qp, union ib_gid *gid, u16 lid);
24692469
int (*detach_mcast)(struct ib_qp *qp, union ib_gid *gid, u16 lid);
24702470
int (*alloc_xrcd)(struct ib_xrcd *xrcd, struct ib_udata *udata);
2471-
void (*dealloc_xrcd)(struct ib_xrcd *xrcd, struct ib_udata *udata);
2471+
int (*dealloc_xrcd)(struct ib_xrcd *xrcd, struct ib_udata *udata);
24722472
struct ib_flow *(*create_flow)(struct ib_qp *qp,
24732473
struct ib_flow_attr *flow_attr,
24742474
int domain, struct ib_udata *udata);

0 commit comments

Comments
 (0)