Commit d7e2d343 authored by Xi Wang's avatar Xi Wang Committed by Jason Gunthorpe

RDMA/hns: Optimize eqe buffer allocation flow

The eqe has a private multi-hop addressing implementation, but there is
already a set of interfaces in the hns driver that can achieve this.

So, simplify the eqe buffer allocation process by using the mtr interface
and remove large amount of repeated logic.

Link: https://lore.kernel.org/r/20200126145835.11368-1-liweihang@huawei.comSigned-off-by: default avatarXi Wang <wangxi11@huawei.com>
Signed-off-by: default avatarWeihang Li <liweihang@huawei.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@mellanox.com>
parent b14c95be
...@@ -762,14 +762,8 @@ struct hns_roce_eq { ...@@ -762,14 +762,8 @@ struct hns_roce_eq {
int eqe_ba_pg_sz; int eqe_ba_pg_sz;
int eqe_buf_pg_sz; int eqe_buf_pg_sz;
int hop_num; int hop_num;
u64 *bt_l0; /* Base address table for L0 */ struct hns_roce_mtr mtr;
u64 **bt_l1; /* Base address table for L1 */ struct hns_roce_buf buf;
u64 **buf;
dma_addr_t l0_dma;
dma_addr_t *l1_dma;
dma_addr_t *buf_dma;
u32 l0_last_num; /* L0 last chunk num */
u32 l1_last_num; /* L1 last chunk num */
int eq_max_cnt; int eq_max_cnt;
int eq_period; int eq_period;
int shift; int shift;
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment