Commit e84d3c18 authored by Michal Kalderon's avatar Michal Kalderon Committed by Jason Gunthorpe

RDMA/efa: Use the common mmap_xa helpers

Remove the functions related to managing the mmap_xa database.  This code
was replaced with common code in ib_core.

Link: https://lore.kernel.org/r/20191030094417.16866-5-michal.kalderon@marvell.comSigned-off-by: default avatarAriel Elior <ariel.elior@marvell.com>
Signed-off-by: default avatarMichal Kalderon <michal.kalderon@marvell.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@mellanox.com>
parent c043ff2c
...@@ -71,8 +71,6 @@ struct efa_dev { ...@@ -71,8 +71,6 @@ struct efa_dev {
struct efa_ucontext { struct efa_ucontext {
struct ib_ucontext ibucontext; struct ib_ucontext ibucontext;
struct xarray mmap_xa;
u32 mmap_xa_page;
u16 uarn; u16 uarn;
}; };
...@@ -91,6 +89,7 @@ struct efa_cq { ...@@ -91,6 +89,7 @@ struct efa_cq {
struct efa_ucontext *ucontext; struct efa_ucontext *ucontext;
dma_addr_t dma_addr; dma_addr_t dma_addr;
void *cpu_addr; void *cpu_addr;
struct rdma_user_mmap_entry *mmap_entry;
size_t size; size_t size;
u16 cq_idx; u16 cq_idx;
}; };
...@@ -101,6 +100,13 @@ struct efa_qp { ...@@ -101,6 +100,13 @@ struct efa_qp {
void *rq_cpu_addr; void *rq_cpu_addr;
size_t rq_size; size_t rq_size;
enum ib_qp_state state; enum ib_qp_state state;
/* Used for saving mmap_xa entries */
struct rdma_user_mmap_entry *sq_db_mmap_entry;
struct rdma_user_mmap_entry *llq_desc_mmap_entry;
struct rdma_user_mmap_entry *rq_db_mmap_entry;
struct rdma_user_mmap_entry *rq_mmap_entry;
u32 qp_handle; u32 qp_handle;
u32 max_send_wr; u32 max_send_wr;
u32 max_recv_wr; u32 max_recv_wr;
...@@ -147,6 +153,7 @@ int efa_alloc_ucontext(struct ib_ucontext *ibucontext, struct ib_udata *udata); ...@@ -147,6 +153,7 @@ int efa_alloc_ucontext(struct ib_ucontext *ibucontext, struct ib_udata *udata);
void efa_dealloc_ucontext(struct ib_ucontext *ibucontext); void efa_dealloc_ucontext(struct ib_ucontext *ibucontext);
int efa_mmap(struct ib_ucontext *ibucontext, int efa_mmap(struct ib_ucontext *ibucontext,
struct vm_area_struct *vma); struct vm_area_struct *vma);
void efa_mmap_free(struct rdma_user_mmap_entry *rdma_entry);
int efa_create_ah(struct ib_ah *ibah, int efa_create_ah(struct ib_ah *ibah,
struct rdma_ah_attr *ah_attr, struct rdma_ah_attr *ah_attr,
u32 flags, u32 flags,
......
...@@ -217,6 +217,7 @@ static const struct ib_device_ops efa_dev_ops = { ...@@ -217,6 +217,7 @@ static const struct ib_device_ops efa_dev_ops = {
.get_link_layer = efa_port_link_layer, .get_link_layer = efa_port_link_layer,
.get_port_immutable = efa_get_port_immutable, .get_port_immutable = efa_get_port_immutable,
.mmap = efa_mmap, .mmap = efa_mmap,
.mmap_free = efa_mmap_free,
.modify_qp = efa_modify_qp, .modify_qp = efa_modify_qp,
.query_device = efa_query_device, .query_device = efa_query_device,
.query_gid = efa_query_gid, .query_gid = efa_query_gid,
......
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