mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-10-04 16:15:11 +00:00
RDMA/hns: Use IDA interface to manage mtpt index
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.com Signed-off-by: Yangyang Li <liyangyang20@huawei.com> Signed-off-by: Weihang Li <liweihang@huawei.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
This commit is contained in:
parent
38e375b771
commit
d38936f010
5 changed files with 43 additions and 48 deletions
|
@ -251,7 +251,7 @@ void hns_roce_cleanup_bitmap(struct hns_roce_dev *hr_dev)
|
|||
hns_roce_cleanup_srq_table(hr_dev);
|
||||
hns_roce_cleanup_qp_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_uar_table(hr_dev);
|
||||
}
|
||||
|
|
|
@ -253,6 +253,12 @@ struct hns_roce_bitmap {
|
|||
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 */
|
||||
struct hns_roce_hem_table {
|
||||
/* HEM type: 0 = qpc, 1 = mtt, 2 = cqc, 3 = srq, 4 = other */
|
||||
|
@ -345,7 +351,7 @@ struct hns_roce_mr {
|
|||
};
|
||||
|
||||
struct hns_roce_mr_table {
|
||||
struct hns_roce_bitmap mtpt_bitmap;
|
||||
struct hns_roce_ida mtpt_ida;
|
||||
struct hns_roce_hem_table mtpt_table;
|
||||
};
|
||||
|
||||
|
@ -1138,14 +1144,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);
|
||||
|
||||
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);
|
||||
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_xrcd_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_cq_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,
|
|||
dev_dbg(dev, "Free mr 0x%x use 0x%x us.\n",
|
||||
mr->key, jiffies_to_usecs(jiffies) - jiffies_to_usecs(start));
|
||||
|
||||
hns_roce_bitmap_free(&hr_dev->mr_table.mtpt_bitmap,
|
||||
key_to_hw_index(mr->key));
|
||||
ida_free(&hr_dev->mr_table.mtpt_ida.ida, (int)key_to_hw_index(mr->key));
|
||||
hns_roce_mtr_destroy(hr_dev, &mr->pbl_mtr);
|
||||
kfree(mr);
|
||||
|
||||
|
|
|
@ -763,11 +763,7 @@ static int hns_roce_setup_hca(struct hns_roce_dev *hr_dev)
|
|||
}
|
||||
}
|
||||
|
||||
ret = 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_mr_table(hr_dev);
|
||||
|
||||
hns_roce_init_cq_table(hr_dev);
|
||||
|
||||
|
@ -793,9 +789,8 @@ static int hns_roce_setup_hca(struct hns_roce_dev *hr_dev)
|
|||
|
||||
err_cq_table_free:
|
||||
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)
|
||||
hns_roce_cleanup_xrcd_table(hr_dev);
|
||||
|
||||
|
|
|
@ -38,9 +38,9 @@
|
|||
#include "hns_roce_cmd.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)
|
||||
|
@ -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)
|
||||
{
|
||||
struct hns_roce_ida *mtpt_ida = &hr_dev->mr_table.mtpt_ida;
|
||||
struct ib_device *ibdev = &hr_dev->ib_dev;
|
||||
unsigned long obj = 0;
|
||||
int err;
|
||||
int id;
|
||||
|
||||
/* Allocate a key for mr from mr_table */
|
||||
err = hns_roce_bitmap_alloc(&hr_dev->mr_table.mtpt_bitmap, &obj);
|
||||
if (err) {
|
||||
ibdev_err(ibdev,
|
||||
"failed to alloc bitmap for MR key, ret = %d.\n",
|
||||
err);
|
||||
id = ida_alloc_range(&mtpt_ida->ida, mtpt_ida->min, mtpt_ida->max,
|
||||
GFP_KERNEL);
|
||||
if (id < 0) {
|
||||
ibdev_err(ibdev, "failed to alloc id for MR key, id(%d)\n", id);
|
||||
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) {
|
||||
ibdev_err(ibdev, "failed to alloc mtpt, ret = %d.\n", err);
|
||||
goto err_free_bitmap;
|
||||
|
@ -91,7 +92,7 @@ static int alloc_mr_key(struct hns_roce_dev *hr_dev, struct hns_roce_mr *mr)
|
|||
|
||||
return 0;
|
||||
err_free_bitmap:
|
||||
hns_roce_bitmap_free(&hr_dev->mr_table.mtpt_bitmap, obj);
|
||||
ida_free(&mtpt_ida->ida, id);
|
||||
return err;
|
||||
}
|
||||
|
||||
|
@ -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);
|
||||
|
||||
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,
|
||||
|
@ -196,23 +197,13 @@ static int hns_roce_mr_enable(struct hns_roce_dev *hr_dev,
|
|||
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;
|
||||
struct hns_roce_ida *mtpt_ida = &hr_dev->mr_table.mtpt_ida;
|
||||
|
||||
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;
|
||||
|
||||
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)
|
||||
|
@ -503,8 +494,8 @@ static void hns_roce_mw_free(struct hns_roce_dev *hr_dev,
|
|||
key_to_hw_index(mw->rkey));
|
||||
}
|
||||
|
||||
hns_roce_bitmap_free(&hr_dev->mr_table.mtpt_bitmap,
|
||||
key_to_hw_index(mw->rkey));
|
||||
ida_free(&hr_dev->mr_table.mtpt_ida.ida,
|
||||
(int)key_to_hw_index(mw->rkey));
|
||||
}
|
||||
|
||||
static int hns_roce_mw_enable(struct hns_roce_dev *hr_dev,
|
||||
|
@ -558,16 +549,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)
|
||||
{
|
||||
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);
|
||||
unsigned long index = 0;
|
||||
int ret;
|
||||
int id;
|
||||
|
||||
/* Allocate a key for mw from bitmap */
|
||||
ret = hns_roce_bitmap_alloc(&hr_dev->mr_table.mtpt_bitmap, &index);
|
||||
if (ret)
|
||||
return ret;
|
||||
/* Allocate a key for mw from mr_table */
|
||||
id = ida_alloc_range(&mtpt_ida->ida, mtpt_ida->min, mtpt_ida->max,
|
||||
GFP_KERNEL);
|
||||
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;
|
||||
mw->pdn = to_hr_pd(ibmw->pd)->pdn;
|
||||
|
|
Loading…
Reference in a new issue