提交 5b80e789 编写于 作者: Y Yangyang Li 提交者: Zheng Zengkai

RDMA/hns: Use IDA interface to manage mtpt index

mainline inclusion
from mainline-v5.12-rc1
commit d38936f0
category: bugfix
bugzilla: 174002
CVE:NA

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=d38936f01030f39bd90609c4d9c8f09cdaea1b62

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

Switch mtpt index allocation and release from hns own bitmap interface
to IDA interface.

Link: https://lore.kernel.org/r/1623325814-55737-5-git-send-email-liweihang@huawei.comSigned-off-by: NYangyang Li <liyangyang20@huawei.com>
Signed-off-by: NWeihang Li <liweihang@huawei.com>
Signed-off-by: NJason Gunthorpe <jgg@nvidia.com>
Signed-off-by: Nwangsirong <wangsirong@huawei.com>
Reviewed-by: NChunZhi Hu <huchunzhi@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 6af5f8a5
...@@ -260,7 +260,7 @@ void hns_roce_cleanup_bitmap(struct hns_roce_dev *hr_dev) ...@@ -260,7 +260,7 @@ void hns_roce_cleanup_bitmap(struct hns_roce_dev *hr_dev)
hns_roce_cleanup_srq_table(hr_dev); hns_roce_cleanup_srq_table(hr_dev);
hns_roce_cleanup_qp_table(hr_dev); hns_roce_cleanup_qp_table(hr_dev);
hns_roce_cleanup_cq_table(hr_dev); hns_roce_cleanup_cq_table(hr_dev);
hns_roce_cleanup_mr_table(hr_dev); ida_destroy(&hr_dev->mr_table.mtpt_ida.ida);
hns_roce_cleanup_pd_table(hr_dev); hns_roce_cleanup_pd_table(hr_dev);
hns_roce_cleanup_uar_table(hr_dev); hns_roce_cleanup_uar_table(hr_dev);
} }
...@@ -253,6 +253,12 @@ struct hns_roce_bitmap { ...@@ -253,6 +253,12 @@ struct hns_roce_bitmap {
unsigned long *table; unsigned long *table;
}; };
struct hns_roce_ida {
struct ida ida;
u32 min; /* Lowest ID to allocate. */
u32 max; /* Highest ID to allocate. */
};
/* For Hardware Entry Memory */ /* For Hardware Entry Memory */
struct hns_roce_hem_table { struct hns_roce_hem_table {
/* HEM type: 0 = qpc, 1 = mtt, 2 = cqc, 3 = srq, 4 = other */ /* HEM type: 0 = qpc, 1 = mtt, 2 = cqc, 3 = srq, 4 = other */
...@@ -345,7 +351,7 @@ struct hns_roce_mr { ...@@ -345,7 +351,7 @@ struct hns_roce_mr {
}; };
struct hns_roce_mr_table { struct hns_roce_mr_table {
struct hns_roce_bitmap mtpt_bitmap; struct hns_roce_ida mtpt_ida;
struct hns_roce_hem_table mtpt_table; struct hns_roce_hem_table mtpt_table;
}; };
...@@ -1134,14 +1140,13 @@ int hns_roce_mtr_map(struct hns_roce_dev *hr_dev, struct hns_roce_mtr *mtr, ...@@ -1134,14 +1140,13 @@ int hns_roce_mtr_map(struct hns_roce_dev *hr_dev, struct hns_roce_mtr *mtr,
dma_addr_t *pages, unsigned int page_cnt); dma_addr_t *pages, unsigned int page_cnt);
int hns_roce_init_pd_table(struct hns_roce_dev *hr_dev); int hns_roce_init_pd_table(struct hns_roce_dev *hr_dev);
int hns_roce_init_mr_table(struct hns_roce_dev *hr_dev); void hns_roce_init_mr_table(struct hns_roce_dev *hr_dev);
void hns_roce_init_cq_table(struct hns_roce_dev *hr_dev); void hns_roce_init_cq_table(struct hns_roce_dev *hr_dev);
int hns_roce_init_qp_table(struct hns_roce_dev *hr_dev); int hns_roce_init_qp_table(struct hns_roce_dev *hr_dev);
int hns_roce_init_srq_table(struct hns_roce_dev *hr_dev); int hns_roce_init_srq_table(struct hns_roce_dev *hr_dev);
int hns_roce_init_xrcd_table(struct hns_roce_dev *hr_dev); int hns_roce_init_xrcd_table(struct hns_roce_dev *hr_dev);
void hns_roce_cleanup_pd_table(struct hns_roce_dev *hr_dev); void hns_roce_cleanup_pd_table(struct hns_roce_dev *hr_dev);
void hns_roce_cleanup_mr_table(struct hns_roce_dev *hr_dev);
void hns_roce_cleanup_eq_table(struct hns_roce_dev *hr_dev); void hns_roce_cleanup_eq_table(struct hns_roce_dev *hr_dev);
void hns_roce_cleanup_cq_table(struct hns_roce_dev *hr_dev); void hns_roce_cleanup_cq_table(struct hns_roce_dev *hr_dev);
void hns_roce_cleanup_qp_table(struct hns_roce_dev *hr_dev); void hns_roce_cleanup_qp_table(struct hns_roce_dev *hr_dev);
......
...@@ -1198,8 +1198,7 @@ static int hns_roce_v1_dereg_mr(struct hns_roce_dev *hr_dev, ...@@ -1198,8 +1198,7 @@ static int hns_roce_v1_dereg_mr(struct hns_roce_dev *hr_dev,
dev_dbg(dev, "Free mr 0x%x use 0x%x us.\n", dev_dbg(dev, "Free mr 0x%x use 0x%x us.\n",
mr->key, jiffies_to_usecs(jiffies) - jiffies_to_usecs(start)); mr->key, jiffies_to_usecs(jiffies) - jiffies_to_usecs(start));
hns_roce_bitmap_free(&hr_dev->mr_table.mtpt_bitmap, ida_free(&hr_dev->mr_table.mtpt_ida.ida, (int)key_to_hw_index(mr->key));
key_to_hw_index(mr->key));
hns_roce_mtr_destroy(hr_dev, &mr->pbl_mtr); hns_roce_mtr_destroy(hr_dev, &mr->pbl_mtr);
kfree(mr); kfree(mr);
......
...@@ -799,11 +799,7 @@ static int hns_roce_setup_hca(struct hns_roce_dev *hr_dev) ...@@ -799,11 +799,7 @@ static int hns_roce_setup_hca(struct hns_roce_dev *hr_dev)
} }
} }
ret = hns_roce_init_mr_table(hr_dev); hns_roce_init_mr_table(hr_dev);
if (ret) {
dev_err(dev, "Failed to init memory region table.\n");
goto err_xrcd_table_free;
}
hns_roce_init_cq_table(hr_dev); hns_roce_init_cq_table(hr_dev);
...@@ -829,9 +825,8 @@ static int hns_roce_setup_hca(struct hns_roce_dev *hr_dev) ...@@ -829,9 +825,8 @@ static int hns_roce_setup_hca(struct hns_roce_dev *hr_dev)
err_cq_table_free: err_cq_table_free:
hns_roce_cleanup_cq_table(hr_dev); hns_roce_cleanup_cq_table(hr_dev);
hns_roce_cleanup_mr_table(hr_dev); ida_destroy(&hr_dev->mr_table.mtpt_ida.ida);
err_xrcd_table_free:
if (hr_dev->caps.flags & HNS_ROCE_CAP_FLAG_XRC) if (hr_dev->caps.flags & HNS_ROCE_CAP_FLAG_XRC)
hns_roce_cleanup_xrcd_table(hr_dev); hns_roce_cleanup_xrcd_table(hr_dev);
......
...@@ -38,9 +38,9 @@ ...@@ -38,9 +38,9 @@
#include "hns_roce_cmd.h" #include "hns_roce_cmd.h"
#include "hns_roce_hem.h" #include "hns_roce_hem.h"
static u32 hw_index_to_key(unsigned long ind) static u32 hw_index_to_key(int ind)
{ {
return (u32)(ind >> 24) | (ind << 8); return ((u32)ind >> 24) | ((u32)ind << 8);
} }
unsigned long key_to_hw_index(u32 key) unsigned long key_to_hw_index(u32 key)
...@@ -68,22 +68,23 @@ int hns_roce_hw_destroy_mpt(struct hns_roce_dev *hr_dev, ...@@ -68,22 +68,23 @@ int hns_roce_hw_destroy_mpt(struct hns_roce_dev *hr_dev,
static int alloc_mr_key(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr) static int alloc_mr_key(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr)
{ {
struct hns_roce_ida *mtpt_ida = &hr_dev->mr_table.mtpt_ida;
struct ib_device *ibdev = &hr_dev->ib_dev; struct ib_device *ibdev = &hr_dev->ib_dev;
unsigned long obj = 0;
int err; int err;
int id;
/* Allocate a key for mr from mr_table */ /* Allocate a key for mr from mr_table */
err = hns_roce_bitmap_alloc(&hr_dev->mr_table.mtpt_bitmap, &obj); id = ida_alloc_range(&mtpt_ida->ida, mtpt_ida->min, mtpt_ida->max,
if (err) { GFP_KERNEL);
ibdev_err(ibdev, if (id < 0) {
"failed to alloc bitmap for MR key, ret = %d.\n", ibdev_err(ibdev, "failed to alloc id for MR key, id(%d)\n", id);
err);
return -ENOMEM; return -ENOMEM;
} }
mr->key = hw_index_to_key(obj); /* MR key */ mr->key = hw_index_to_key(id); /* MR key */
err = hns_roce_table_get(hr_dev, &hr_dev->mr_table.mtpt_table, obj); err = hns_roce_table_get(hr_dev, &hr_dev->mr_table.mtpt_table,
(unsigned long)id);
if (err) { if (err) {
ibdev_err(ibdev, "failed to alloc mtpt, ret = %d.\n", err); ibdev_err(ibdev, "failed to alloc mtpt, ret = %d.\n", err);
goto err_free_bitmap; goto err_free_bitmap;
...@@ -91,7 +92,7 @@ static int alloc_mr_key(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr) ...@@ -91,7 +92,7 @@ static int alloc_mr_key(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr)
return 0; return 0;
err_free_bitmap: err_free_bitmap:
hns_roce_bitmap_free(&hr_dev->mr_table.mtpt_bitmap, obj); ida_free(&mtpt_ida->ida, id);
return err; return err;
} }
...@@ -100,7 +101,7 @@ static void free_mr_key(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr) ...@@ -100,7 +101,7 @@ static void free_mr_key(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr)
unsigned long obj = key_to_hw_index(mr->key); unsigned long obj = key_to_hw_index(mr->key);
hns_roce_table_put(hr_dev, &hr_dev->mr_table.mtpt_table, obj); hns_roce_table_put(hr_dev, &hr_dev->mr_table.mtpt_table, obj);
hns_roce_bitmap_free(&hr_dev->mr_table.mtpt_bitmap, obj); ida_free(&hr_dev->mr_table.mtpt_ida.ida, (int)obj);
} }
static int alloc_mr_pbl(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr, static int alloc_mr_pbl(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr,
...@@ -196,23 +197,13 @@ static int hns_roce_mr_enable(struct hns_roce_dev *hr_dev, ...@@ -196,23 +197,13 @@ static int hns_roce_mr_enable(struct hns_roce_dev *hr_dev,
return ret; return ret;
} }
int hns_roce_init_mr_table(struct hns_roce_dev *hr_dev) void hns_roce_init_mr_table(struct hns_roce_dev *hr_dev)
{
struct hns_roce_mr_table *mr_table = &hr_dev->mr_table;
int ret;
ret = hns_roce_bitmap_init(&mr_table->mtpt_bitmap,
hr_dev->caps.num_mtpts,
hr_dev->caps.num_mtpts - 1,
hr_dev->caps.reserved_mrws, 0);
return ret;
}
void hns_roce_cleanup_mr_table(struct hns_roce_dev *hr_dev)
{ {
struct hns_roce_mr_table *mr_table = &hr_dev->mr_table; struct hns_roce_ida *mtpt_ida = &hr_dev->mr_table.mtpt_ida;
hns_roce_bitmap_cleanup(&mr_table->mtpt_bitmap); ida_init(&mtpt_ida->ida);
mtpt_ida->max = hr_dev->caps.num_mtpts - 1;
mtpt_ida->min = hr_dev->caps.reserved_mrws;
} }
struct ib_mr *hns_roce_get_dma_mr(struct ib_pd *pd, int acc) struct ib_mr *hns_roce_get_dma_mr(struct ib_pd *pd, int acc)
...@@ -502,8 +493,8 @@ static void hns_roce_mw_free(struct hns_roce_dev *hr_dev, ...@@ -502,8 +493,8 @@ static void hns_roce_mw_free(struct hns_roce_dev *hr_dev,
key_to_hw_index(mw->rkey)); key_to_hw_index(mw->rkey));
} }
hns_roce_bitmap_free(&hr_dev->mr_table.mtpt_bitmap, ida_free(&hr_dev->mr_table.mtpt_ida.ida,
key_to_hw_index(mw->rkey)); (int)key_to_hw_index(mw->rkey));
} }
static int hns_roce_mw_enable(struct hns_roce_dev *hr_dev, static int hns_roce_mw_enable(struct hns_roce_dev *hr_dev,
...@@ -557,16 +548,21 @@ static int hns_roce_mw_enable(struct hns_roce_dev *hr_dev, ...@@ -557,16 +548,21 @@ static int hns_roce_mw_enable(struct hns_roce_dev *hr_dev,
int hns_roce_alloc_mw(struct ib_mw *ibmw, struct ib_udata *udata) int hns_roce_alloc_mw(struct ib_mw *ibmw, struct ib_udata *udata)
{ {
struct hns_roce_dev *hr_dev = to_hr_dev(ibmw->device); struct hns_roce_dev *hr_dev = to_hr_dev(ibmw->device);
struct hns_roce_ida *mtpt_ida = &hr_dev->mr_table.mtpt_ida;
struct ib_device *ibdev = &hr_dev->ib_dev;
struct hns_roce_mw *mw = to_hr_mw(ibmw); struct hns_roce_mw *mw = to_hr_mw(ibmw);
unsigned long index = 0;
int ret; int ret;
int id;
/* Allocate a key for mw from bitmap */ /* Allocate a key for mw from mr_table */
ret = hns_roce_bitmap_alloc(&hr_dev->mr_table.mtpt_bitmap, &index); id = ida_alloc_range(&mtpt_ida->ida, mtpt_ida->min, mtpt_ida->max,
if (ret) GFP_KERNEL);
return ret; if (id < 0) {
ibdev_err(ibdev, "failed to alloc id for MW key, id(%d)\n", id);
return -ENOMEM;
}
mw->rkey = hw_index_to_key(index); mw->rkey = hw_index_to_key(id);
ibmw->rkey = mw->rkey; ibmw->rkey = mw->rkey;
mw->pdn = to_hr_pd(ibmw->pd)->pdn; mw->pdn = to_hr_pd(ibmw->pd)->pdn;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册