mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-10 23:29:46 +00:00
RDMA/rxe: Cleanup rxe_pool_entry
Currently three different names are used to describe rxe pool elements. They are referred to as entries, elems or pelems. This patch chooses one 'elem' and changes the other ones. Link: https://lore.kernel.org/r/20211103050241.61293-3-rpearsonhpe@gmail.com Signed-off-by: Bob Pearson <rpearsonhpe@gmail.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
This commit is contained in:
parent
21adfa7a3c
commit
02827b6708
@ -146,9 +146,9 @@ void rxe_cq_disable(struct rxe_cq *cq)
|
||||
spin_unlock_bh(&cq->cq_lock);
|
||||
}
|
||||
|
||||
void rxe_cq_cleanup(struct rxe_pool_entry *arg)
|
||||
void rxe_cq_cleanup(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_cq *cq = container_of(arg, typeof(*cq), pelem);
|
||||
struct rxe_cq *cq = container_of(elem, typeof(*cq), elem);
|
||||
|
||||
if (cq->queue)
|
||||
rxe_queue_cleanup(cq->queue);
|
||||
|
@ -37,7 +37,7 @@ int rxe_cq_post(struct rxe_cq *cq, struct rxe_cqe *cqe, int solicited);
|
||||
|
||||
void rxe_cq_disable(struct rxe_cq *cq);
|
||||
|
||||
void rxe_cq_cleanup(struct rxe_pool_entry *arg);
|
||||
void rxe_cq_cleanup(struct rxe_pool_elem *arg);
|
||||
|
||||
/* rxe_mcast.c */
|
||||
int rxe_mcast_get_grp(struct rxe_dev *rxe, union ib_gid *mgid,
|
||||
@ -51,7 +51,7 @@ int rxe_mcast_drop_grp_elem(struct rxe_dev *rxe, struct rxe_qp *qp,
|
||||
|
||||
void rxe_drop_all_mcast_groups(struct rxe_qp *qp);
|
||||
|
||||
void rxe_mc_cleanup(struct rxe_pool_entry *arg);
|
||||
void rxe_mc_cleanup(struct rxe_pool_elem *arg);
|
||||
|
||||
/* rxe_mmap.c */
|
||||
struct rxe_mmap_info {
|
||||
@ -89,7 +89,7 @@ int rxe_invalidate_mr(struct rxe_qp *qp, u32 rkey);
|
||||
int rxe_reg_fast_mr(struct rxe_qp *qp, struct rxe_send_wqe *wqe);
|
||||
int rxe_mr_set_page(struct ib_mr *ibmr, u64 addr);
|
||||
int rxe_dereg_mr(struct ib_mr *ibmr, struct ib_udata *udata);
|
||||
void rxe_mr_cleanup(struct rxe_pool_entry *arg);
|
||||
void rxe_mr_cleanup(struct rxe_pool_elem *arg);
|
||||
|
||||
/* rxe_mw.c */
|
||||
int rxe_alloc_mw(struct ib_mw *ibmw, struct ib_udata *udata);
|
||||
@ -97,7 +97,7 @@ int rxe_dealloc_mw(struct ib_mw *ibmw);
|
||||
int rxe_bind_mw(struct rxe_qp *qp, struct rxe_send_wqe *wqe);
|
||||
int rxe_invalidate_mw(struct rxe_qp *qp, u32 rkey);
|
||||
struct rxe_mw *rxe_lookup_mw(struct rxe_qp *qp, int access, u32 rkey);
|
||||
void rxe_mw_cleanup(struct rxe_pool_entry *arg);
|
||||
void rxe_mw_cleanup(struct rxe_pool_elem *arg);
|
||||
|
||||
/* rxe_net.c */
|
||||
struct sk_buff *rxe_init_packet(struct rxe_dev *rxe, struct rxe_av *av,
|
||||
@ -131,7 +131,7 @@ void rxe_qp_error(struct rxe_qp *qp);
|
||||
|
||||
void rxe_qp_destroy(struct rxe_qp *qp);
|
||||
|
||||
void rxe_qp_cleanup(struct rxe_pool_entry *arg);
|
||||
void rxe_qp_cleanup(struct rxe_pool_elem *elem);
|
||||
|
||||
static inline int qp_num(struct rxe_qp *qp)
|
||||
{
|
||||
|
@ -168,9 +168,9 @@ void rxe_drop_all_mcast_groups(struct rxe_qp *qp)
|
||||
}
|
||||
}
|
||||
|
||||
void rxe_mc_cleanup(struct rxe_pool_entry *arg)
|
||||
void rxe_mc_cleanup(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_mc_grp *grp = container_of(arg, typeof(*grp), pelem);
|
||||
struct rxe_mc_grp *grp = container_of(elem, typeof(*grp), elem);
|
||||
struct rxe_dev *rxe = grp->rxe;
|
||||
|
||||
rxe_drop_key(grp);
|
||||
|
@ -50,7 +50,7 @@ int mr_check_range(struct rxe_mr *mr, u64 iova, size_t length)
|
||||
|
||||
static void rxe_mr_init(int access, struct rxe_mr *mr)
|
||||
{
|
||||
u32 lkey = mr->pelem.index << 8 | rxe_get_next_key(-1);
|
||||
u32 lkey = mr->elem.index << 8 | rxe_get_next_key(-1);
|
||||
u32 rkey = (access & IB_ACCESS_REMOTE) ? lkey : 0;
|
||||
|
||||
/* set ibmr->l/rkey and also copy into private l/rkey
|
||||
@ -699,9 +699,9 @@ int rxe_dereg_mr(struct ib_mr *ibmr, struct ib_udata *udata)
|
||||
return 0;
|
||||
}
|
||||
|
||||
void rxe_mr_cleanup(struct rxe_pool_entry *arg)
|
||||
void rxe_mr_cleanup(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_mr *mr = container_of(arg, typeof(*mr), pelem);
|
||||
struct rxe_mr *mr = container_of(elem, typeof(*mr), elem);
|
||||
|
||||
ib_umem_release(mr->umem);
|
||||
|
||||
|
@ -21,7 +21,7 @@ int rxe_alloc_mw(struct ib_mw *ibmw, struct ib_udata *udata)
|
||||
}
|
||||
|
||||
rxe_add_index(mw);
|
||||
mw->rkey = ibmw->rkey = (mw->pelem.index << 8) | rxe_get_next_key(-1);
|
||||
mw->rkey = ibmw->rkey = (mw->elem.index << 8) | rxe_get_next_key(-1);
|
||||
mw->state = (mw->ibmw.type == IB_MW_TYPE_2) ?
|
||||
RXE_MW_STATE_FREE : RXE_MW_STATE_VALID;
|
||||
spin_lock_init(&mw->lock);
|
||||
@ -330,9 +330,9 @@ struct rxe_mw *rxe_lookup_mw(struct rxe_qp *qp, int access, u32 rkey)
|
||||
return mw;
|
||||
}
|
||||
|
||||
void rxe_mw_cleanup(struct rxe_pool_entry *elem)
|
||||
void rxe_mw_cleanup(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_mw *mw = container_of(elem, typeof(*mw), pelem);
|
||||
struct rxe_mw *mw = container_of(elem, typeof(*mw), elem);
|
||||
|
||||
rxe_drop_index(mw);
|
||||
}
|
||||
|
@ -11,7 +11,7 @@ static const struct rxe_type_info {
|
||||
const char *name;
|
||||
size_t size;
|
||||
size_t elem_offset;
|
||||
void (*cleanup)(struct rxe_pool_entry *obj);
|
||||
void (*cleanup)(struct rxe_pool_elem *obj);
|
||||
enum rxe_pool_flags flags;
|
||||
u32 min_index;
|
||||
u32 max_index;
|
||||
@ -21,19 +21,19 @@ static const struct rxe_type_info {
|
||||
[RXE_TYPE_UC] = {
|
||||
.name = "rxe-uc",
|
||||
.size = sizeof(struct rxe_ucontext),
|
||||
.elem_offset = offsetof(struct rxe_ucontext, pelem),
|
||||
.elem_offset = offsetof(struct rxe_ucontext, elem),
|
||||
.flags = RXE_POOL_NO_ALLOC,
|
||||
},
|
||||
[RXE_TYPE_PD] = {
|
||||
.name = "rxe-pd",
|
||||
.size = sizeof(struct rxe_pd),
|
||||
.elem_offset = offsetof(struct rxe_pd, pelem),
|
||||
.elem_offset = offsetof(struct rxe_pd, elem),
|
||||
.flags = RXE_POOL_NO_ALLOC,
|
||||
},
|
||||
[RXE_TYPE_AH] = {
|
||||
.name = "rxe-ah",
|
||||
.size = sizeof(struct rxe_ah),
|
||||
.elem_offset = offsetof(struct rxe_ah, pelem),
|
||||
.elem_offset = offsetof(struct rxe_ah, elem),
|
||||
.flags = RXE_POOL_INDEX | RXE_POOL_NO_ALLOC,
|
||||
.min_index = RXE_MIN_AH_INDEX,
|
||||
.max_index = RXE_MAX_AH_INDEX,
|
||||
@ -41,7 +41,7 @@ static const struct rxe_type_info {
|
||||
[RXE_TYPE_SRQ] = {
|
||||
.name = "rxe-srq",
|
||||
.size = sizeof(struct rxe_srq),
|
||||
.elem_offset = offsetof(struct rxe_srq, pelem),
|
||||
.elem_offset = offsetof(struct rxe_srq, elem),
|
||||
.flags = RXE_POOL_INDEX | RXE_POOL_NO_ALLOC,
|
||||
.min_index = RXE_MIN_SRQ_INDEX,
|
||||
.max_index = RXE_MAX_SRQ_INDEX,
|
||||
@ -49,7 +49,7 @@ static const struct rxe_type_info {
|
||||
[RXE_TYPE_QP] = {
|
||||
.name = "rxe-qp",
|
||||
.size = sizeof(struct rxe_qp),
|
||||
.elem_offset = offsetof(struct rxe_qp, pelem),
|
||||
.elem_offset = offsetof(struct rxe_qp, elem),
|
||||
.cleanup = rxe_qp_cleanup,
|
||||
.flags = RXE_POOL_INDEX | RXE_POOL_NO_ALLOC,
|
||||
.min_index = RXE_MIN_QP_INDEX,
|
||||
@ -58,14 +58,14 @@ static const struct rxe_type_info {
|
||||
[RXE_TYPE_CQ] = {
|
||||
.name = "rxe-cq",
|
||||
.size = sizeof(struct rxe_cq),
|
||||
.elem_offset = offsetof(struct rxe_cq, pelem),
|
||||
.elem_offset = offsetof(struct rxe_cq, elem),
|
||||
.flags = RXE_POOL_NO_ALLOC,
|
||||
.cleanup = rxe_cq_cleanup,
|
||||
},
|
||||
[RXE_TYPE_MR] = {
|
||||
.name = "rxe-mr",
|
||||
.size = sizeof(struct rxe_mr),
|
||||
.elem_offset = offsetof(struct rxe_mr, pelem),
|
||||
.elem_offset = offsetof(struct rxe_mr, elem),
|
||||
.cleanup = rxe_mr_cleanup,
|
||||
.flags = RXE_POOL_INDEX,
|
||||
.min_index = RXE_MIN_MR_INDEX,
|
||||
@ -74,7 +74,7 @@ static const struct rxe_type_info {
|
||||
[RXE_TYPE_MW] = {
|
||||
.name = "rxe-mw",
|
||||
.size = sizeof(struct rxe_mw),
|
||||
.elem_offset = offsetof(struct rxe_mw, pelem),
|
||||
.elem_offset = offsetof(struct rxe_mw, elem),
|
||||
.cleanup = rxe_mw_cleanup,
|
||||
.flags = RXE_POOL_INDEX | RXE_POOL_NO_ALLOC,
|
||||
.min_index = RXE_MIN_MW_INDEX,
|
||||
@ -83,7 +83,7 @@ static const struct rxe_type_info {
|
||||
[RXE_TYPE_MC_GRP] = {
|
||||
.name = "rxe-mc_grp",
|
||||
.size = sizeof(struct rxe_mc_grp),
|
||||
.elem_offset = offsetof(struct rxe_mc_grp, pelem),
|
||||
.elem_offset = offsetof(struct rxe_mc_grp, elem),
|
||||
.cleanup = rxe_mc_cleanup,
|
||||
.flags = RXE_POOL_KEY,
|
||||
.key_offset = offsetof(struct rxe_mc_grp, mgid),
|
||||
@ -92,7 +92,7 @@ static const struct rxe_type_info {
|
||||
[RXE_TYPE_MC_ELEM] = {
|
||||
.name = "rxe-mc_elem",
|
||||
.size = sizeof(struct rxe_mc_elem),
|
||||
.elem_offset = offsetof(struct rxe_mc_elem, pelem),
|
||||
.elem_offset = offsetof(struct rxe_mc_elem, elem),
|
||||
},
|
||||
};
|
||||
|
||||
@ -189,15 +189,15 @@ static u32 alloc_index(struct rxe_pool *pool)
|
||||
return index + pool->index.min_index;
|
||||
}
|
||||
|
||||
static int rxe_insert_index(struct rxe_pool *pool, struct rxe_pool_entry *new)
|
||||
static int rxe_insert_index(struct rxe_pool *pool, struct rxe_pool_elem *new)
|
||||
{
|
||||
struct rb_node **link = &pool->index.tree.rb_node;
|
||||
struct rb_node *parent = NULL;
|
||||
struct rxe_pool_entry *elem;
|
||||
struct rxe_pool_elem *elem;
|
||||
|
||||
while (*link) {
|
||||
parent = *link;
|
||||
elem = rb_entry(parent, struct rxe_pool_entry, index_node);
|
||||
elem = rb_entry(parent, struct rxe_pool_elem, index_node);
|
||||
|
||||
if (elem->index == new->index) {
|
||||
pr_warn("element already exists!\n");
|
||||
@ -216,16 +216,16 @@ static int rxe_insert_index(struct rxe_pool *pool, struct rxe_pool_entry *new)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int rxe_insert_key(struct rxe_pool *pool, struct rxe_pool_entry *new)
|
||||
static int rxe_insert_key(struct rxe_pool *pool, struct rxe_pool_elem *new)
|
||||
{
|
||||
struct rb_node **link = &pool->key.tree.rb_node;
|
||||
struct rb_node *parent = NULL;
|
||||
struct rxe_pool_entry *elem;
|
||||
struct rxe_pool_elem *elem;
|
||||
int cmp;
|
||||
|
||||
while (*link) {
|
||||
parent = *link;
|
||||
elem = rb_entry(parent, struct rxe_pool_entry, key_node);
|
||||
elem = rb_entry(parent, struct rxe_pool_elem, key_node);
|
||||
|
||||
cmp = memcmp((u8 *)elem + pool->key.key_offset,
|
||||
(u8 *)new + pool->key.key_offset, pool->key.key_size);
|
||||
@ -247,7 +247,7 @@ static int rxe_insert_key(struct rxe_pool *pool, struct rxe_pool_entry *new)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int __rxe_add_key_locked(struct rxe_pool_entry *elem, void *key)
|
||||
int __rxe_add_key_locked(struct rxe_pool_elem *elem, void *key)
|
||||
{
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
int err;
|
||||
@ -258,7 +258,7 @@ int __rxe_add_key_locked(struct rxe_pool_entry *elem, void *key)
|
||||
return err;
|
||||
}
|
||||
|
||||
int __rxe_add_key(struct rxe_pool_entry *elem, void *key)
|
||||
int __rxe_add_key(struct rxe_pool_elem *elem, void *key)
|
||||
{
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
int err;
|
||||
@ -270,14 +270,14 @@ int __rxe_add_key(struct rxe_pool_entry *elem, void *key)
|
||||
return err;
|
||||
}
|
||||
|
||||
void __rxe_drop_key_locked(struct rxe_pool_entry *elem)
|
||||
void __rxe_drop_key_locked(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
|
||||
rb_erase(&elem->key_node, &pool->key.tree);
|
||||
}
|
||||
|
||||
void __rxe_drop_key(struct rxe_pool_entry *elem)
|
||||
void __rxe_drop_key(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
|
||||
@ -286,7 +286,7 @@ void __rxe_drop_key(struct rxe_pool_entry *elem)
|
||||
write_unlock_bh(&pool->pool_lock);
|
||||
}
|
||||
|
||||
int __rxe_add_index_locked(struct rxe_pool_entry *elem)
|
||||
int __rxe_add_index_locked(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
int err;
|
||||
@ -297,7 +297,7 @@ int __rxe_add_index_locked(struct rxe_pool_entry *elem)
|
||||
return err;
|
||||
}
|
||||
|
||||
int __rxe_add_index(struct rxe_pool_entry *elem)
|
||||
int __rxe_add_index(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
int err;
|
||||
@ -309,7 +309,7 @@ int __rxe_add_index(struct rxe_pool_entry *elem)
|
||||
return err;
|
||||
}
|
||||
|
||||
void __rxe_drop_index_locked(struct rxe_pool_entry *elem)
|
||||
void __rxe_drop_index_locked(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
|
||||
@ -317,7 +317,7 @@ void __rxe_drop_index_locked(struct rxe_pool_entry *elem)
|
||||
rb_erase(&elem->index_node, &pool->index.tree);
|
||||
}
|
||||
|
||||
void __rxe_drop_index(struct rxe_pool_entry *elem)
|
||||
void __rxe_drop_index(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
|
||||
@ -329,7 +329,7 @@ void __rxe_drop_index(struct rxe_pool_entry *elem)
|
||||
void *rxe_alloc_locked(struct rxe_pool *pool)
|
||||
{
|
||||
const struct rxe_type_info *info = &rxe_type_info[pool->type];
|
||||
struct rxe_pool_entry *elem;
|
||||
struct rxe_pool_elem *elem;
|
||||
u8 *obj;
|
||||
|
||||
if (atomic_inc_return(&pool->num_elem) > pool->max_elem)
|
||||
@ -339,7 +339,7 @@ void *rxe_alloc_locked(struct rxe_pool *pool)
|
||||
if (!obj)
|
||||
goto out_cnt;
|
||||
|
||||
elem = (struct rxe_pool_entry *)(obj + info->elem_offset);
|
||||
elem = (struct rxe_pool_elem *)(obj + info->elem_offset);
|
||||
|
||||
elem->pool = pool;
|
||||
kref_init(&elem->ref_cnt);
|
||||
@ -354,7 +354,7 @@ out_cnt:
|
||||
void *rxe_alloc(struct rxe_pool *pool)
|
||||
{
|
||||
const struct rxe_type_info *info = &rxe_type_info[pool->type];
|
||||
struct rxe_pool_entry *elem;
|
||||
struct rxe_pool_elem *elem;
|
||||
u8 *obj;
|
||||
|
||||
if (atomic_inc_return(&pool->num_elem) > pool->max_elem)
|
||||
@ -364,7 +364,7 @@ void *rxe_alloc(struct rxe_pool *pool)
|
||||
if (!obj)
|
||||
goto out_cnt;
|
||||
|
||||
elem = (struct rxe_pool_entry *)(obj + info->elem_offset);
|
||||
elem = (struct rxe_pool_elem *)(obj + info->elem_offset);
|
||||
|
||||
elem->pool = pool;
|
||||
kref_init(&elem->ref_cnt);
|
||||
@ -376,7 +376,7 @@ out_cnt:
|
||||
return NULL;
|
||||
}
|
||||
|
||||
int __rxe_add_to_pool(struct rxe_pool *pool, struct rxe_pool_entry *elem)
|
||||
int __rxe_add_to_pool(struct rxe_pool *pool, struct rxe_pool_elem *elem)
|
||||
{
|
||||
if (atomic_inc_return(&pool->num_elem) > pool->max_elem)
|
||||
goto out_cnt;
|
||||
@ -393,8 +393,8 @@ out_cnt:
|
||||
|
||||
void rxe_elem_release(struct kref *kref)
|
||||
{
|
||||
struct rxe_pool_entry *elem =
|
||||
container_of(kref, struct rxe_pool_entry, ref_cnt);
|
||||
struct rxe_pool_elem *elem =
|
||||
container_of(kref, struct rxe_pool_elem, ref_cnt);
|
||||
struct rxe_pool *pool = elem->pool;
|
||||
const struct rxe_type_info *info = &rxe_type_info[pool->type];
|
||||
u8 *obj;
|
||||
@ -414,13 +414,13 @@ void *rxe_pool_get_index_locked(struct rxe_pool *pool, u32 index)
|
||||
{
|
||||
const struct rxe_type_info *info = &rxe_type_info[pool->type];
|
||||
struct rb_node *node;
|
||||
struct rxe_pool_entry *elem;
|
||||
struct rxe_pool_elem *elem;
|
||||
u8 *obj;
|
||||
|
||||
node = pool->index.tree.rb_node;
|
||||
|
||||
while (node) {
|
||||
elem = rb_entry(node, struct rxe_pool_entry, index_node);
|
||||
elem = rb_entry(node, struct rxe_pool_elem, index_node);
|
||||
|
||||
if (elem->index > index)
|
||||
node = node->rb_left;
|
||||
@ -455,14 +455,14 @@ void *rxe_pool_get_key_locked(struct rxe_pool *pool, void *key)
|
||||
{
|
||||
const struct rxe_type_info *info = &rxe_type_info[pool->type];
|
||||
struct rb_node *node;
|
||||
struct rxe_pool_entry *elem;
|
||||
struct rxe_pool_elem *elem;
|
||||
u8 *obj;
|
||||
int cmp;
|
||||
|
||||
node = pool->key.tree.rb_node;
|
||||
|
||||
while (node) {
|
||||
elem = rb_entry(node, struct rxe_pool_entry, key_node);
|
||||
elem = rb_entry(node, struct rxe_pool_elem, key_node);
|
||||
|
||||
cmp = memcmp((u8 *)elem + pool->key.key_offset,
|
||||
key, pool->key.key_size);
|
||||
|
@ -30,9 +30,7 @@ enum rxe_elem_type {
|
||||
RXE_NUM_TYPES, /* keep me last */
|
||||
};
|
||||
|
||||
struct rxe_pool_entry;
|
||||
|
||||
struct rxe_pool_entry {
|
||||
struct rxe_pool_elem {
|
||||
struct rxe_pool *pool;
|
||||
struct kref ref_cnt;
|
||||
struct list_head list;
|
||||
@ -49,7 +47,7 @@ struct rxe_pool {
|
||||
struct rxe_dev *rxe;
|
||||
rwlock_t pool_lock; /* protects pool add/del/search */
|
||||
size_t elem_size;
|
||||
void (*cleanup)(struct rxe_pool_entry *obj);
|
||||
void (*cleanup)(struct rxe_pool_elem *obj);
|
||||
enum rxe_pool_flags flags;
|
||||
enum rxe_elem_type type;
|
||||
|
||||
@ -89,51 +87,51 @@ void *rxe_alloc_locked(struct rxe_pool *pool);
|
||||
void *rxe_alloc(struct rxe_pool *pool);
|
||||
|
||||
/* connect already allocated object to pool */
|
||||
int __rxe_add_to_pool(struct rxe_pool *pool, struct rxe_pool_entry *elem);
|
||||
int __rxe_add_to_pool(struct rxe_pool *pool, struct rxe_pool_elem *elem);
|
||||
|
||||
#define rxe_add_to_pool(pool, obj) __rxe_add_to_pool(pool, &(obj)->pelem)
|
||||
#define rxe_add_to_pool(pool, obj) __rxe_add_to_pool(pool, &(obj)->elem)
|
||||
|
||||
/* assign an index to an indexed object and insert object into
|
||||
* pool's rb tree holding and not holding the pool_lock
|
||||
*/
|
||||
int __rxe_add_index_locked(struct rxe_pool_entry *elem);
|
||||
int __rxe_add_index_locked(struct rxe_pool_elem *elem);
|
||||
|
||||
#define rxe_add_index_locked(obj) __rxe_add_index_locked(&(obj)->pelem)
|
||||
#define rxe_add_index_locked(obj) __rxe_add_index_locked(&(obj)->elem)
|
||||
|
||||
int __rxe_add_index(struct rxe_pool_entry *elem);
|
||||
int __rxe_add_index(struct rxe_pool_elem *elem);
|
||||
|
||||
#define rxe_add_index(obj) __rxe_add_index(&(obj)->pelem)
|
||||
#define rxe_add_index(obj) __rxe_add_index(&(obj)->elem)
|
||||
|
||||
/* drop an index and remove object from rb tree
|
||||
* holding and not holding the pool_lock
|
||||
*/
|
||||
void __rxe_drop_index_locked(struct rxe_pool_entry *elem);
|
||||
void __rxe_drop_index_locked(struct rxe_pool_elem *elem);
|
||||
|
||||
#define rxe_drop_index_locked(obj) __rxe_drop_index_locked(&(obj)->pelem)
|
||||
#define rxe_drop_index_locked(obj) __rxe_drop_index_locked(&(obj)->elem)
|
||||
|
||||
void __rxe_drop_index(struct rxe_pool_entry *elem);
|
||||
void __rxe_drop_index(struct rxe_pool_elem *elem);
|
||||
|
||||
#define rxe_drop_index(obj) __rxe_drop_index(&(obj)->pelem)
|
||||
#define rxe_drop_index(obj) __rxe_drop_index(&(obj)->elem)
|
||||
|
||||
/* assign a key to a keyed object and insert object into
|
||||
* pool's rb tree holding and not holding pool_lock
|
||||
*/
|
||||
int __rxe_add_key_locked(struct rxe_pool_entry *elem, void *key);
|
||||
int __rxe_add_key_locked(struct rxe_pool_elem *elem, void *key);
|
||||
|
||||
#define rxe_add_key_locked(obj, key) __rxe_add_key_locked(&(obj)->pelem, key)
|
||||
#define rxe_add_key_locked(obj, key) __rxe_add_key_locked(&(obj)->elem, key)
|
||||
|
||||
int __rxe_add_key(struct rxe_pool_entry *elem, void *key);
|
||||
int __rxe_add_key(struct rxe_pool_elem *elem, void *key);
|
||||
|
||||
#define rxe_add_key(obj, key) __rxe_add_key(&(obj)->pelem, key)
|
||||
#define rxe_add_key(obj, key) __rxe_add_key(&(obj)->elem, key)
|
||||
|
||||
/* remove elem from rb tree holding and not holding the pool_lock */
|
||||
void __rxe_drop_key_locked(struct rxe_pool_entry *elem);
|
||||
void __rxe_drop_key_locked(struct rxe_pool_elem *elem);
|
||||
|
||||
#define rxe_drop_key_locked(obj) __rxe_drop_key_locked(&(obj)->pelem)
|
||||
#define rxe_drop_key_locked(obj) __rxe_drop_key_locked(&(obj)->elem)
|
||||
|
||||
void __rxe_drop_key(struct rxe_pool_entry *elem);
|
||||
void __rxe_drop_key(struct rxe_pool_elem *elem);
|
||||
|
||||
#define rxe_drop_key(obj) __rxe_drop_key(&(obj)->pelem)
|
||||
#define rxe_drop_key(obj) __rxe_drop_key(&(obj)->elem)
|
||||
|
||||
/* lookup an indexed object from index holding and not holding the pool_lock.
|
||||
* takes a reference on object
|
||||
@ -153,9 +151,9 @@ void *rxe_pool_get_key(struct rxe_pool *pool, void *key);
|
||||
void rxe_elem_release(struct kref *kref);
|
||||
|
||||
/* take a reference on an object */
|
||||
#define rxe_add_ref(elem) kref_get(&(elem)->pelem.ref_cnt)
|
||||
#define rxe_add_ref(obj) kref_get(&(obj)->elem.ref_cnt)
|
||||
|
||||
/* drop a reference on an object */
|
||||
#define rxe_drop_ref(elem) kref_put(&(elem)->pelem.ref_cnt, rxe_elem_release)
|
||||
#define rxe_drop_ref(obj) kref_put(&(obj)->elem.ref_cnt, rxe_elem_release)
|
||||
|
||||
#endif /* RXE_POOL_H */
|
||||
|
@ -167,7 +167,7 @@ static void rxe_qp_init_misc(struct rxe_dev *rxe, struct rxe_qp *qp,
|
||||
qp->attr.path_mtu = 1;
|
||||
qp->mtu = ib_mtu_enum_to_int(qp->attr.path_mtu);
|
||||
|
||||
qpn = qp->pelem.index;
|
||||
qpn = qp->elem.index;
|
||||
port = &rxe->port;
|
||||
|
||||
switch (init->qp_type) {
|
||||
@ -831,9 +831,9 @@ static void rxe_qp_do_cleanup(struct work_struct *work)
|
||||
}
|
||||
|
||||
/* called when the last reference to the qp is dropped */
|
||||
void rxe_qp_cleanup(struct rxe_pool_entry *arg)
|
||||
void rxe_qp_cleanup(struct rxe_pool_elem *elem)
|
||||
{
|
||||
struct rxe_qp *qp = container_of(arg, typeof(*qp), pelem);
|
||||
struct rxe_qp *qp = container_of(elem, typeof(*qp), elem);
|
||||
|
||||
execute_in_process_context(rxe_qp_do_cleanup, &qp->cleanup_work);
|
||||
}
|
||||
|
@ -83,7 +83,7 @@ int rxe_srq_from_init(struct rxe_dev *rxe, struct rxe_srq *srq,
|
||||
srq->ibsrq.event_handler = init->event_handler;
|
||||
srq->ibsrq.srq_context = init->srq_context;
|
||||
srq->limit = init->attr.srq_limit;
|
||||
srq->srq_num = srq->pelem.index;
|
||||
srq->srq_num = srq->elem.index;
|
||||
srq->rq.max_wr = init->attr.max_wr;
|
||||
srq->rq.max_sge = init->attr.max_sge;
|
||||
|
||||
|
@ -182,7 +182,7 @@ static int rxe_create_ah(struct ib_ah *ibah,
|
||||
|
||||
/* create index > 0 */
|
||||
rxe_add_index(ah);
|
||||
ah->ah_num = ah->pelem.index;
|
||||
ah->ah_num = ah->elem.index;
|
||||
|
||||
if (uresp) {
|
||||
/* only if new user provider */
|
||||
|
@ -35,17 +35,17 @@ static inline int psn_compare(u32 psn_a, u32 psn_b)
|
||||
|
||||
struct rxe_ucontext {
|
||||
struct ib_ucontext ibuc;
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
};
|
||||
|
||||
struct rxe_pd {
|
||||
struct ib_pd ibpd;
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
};
|
||||
|
||||
struct rxe_ah {
|
||||
struct ib_ah ibah;
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
struct rxe_av av;
|
||||
bool is_user;
|
||||
int ah_num;
|
||||
@ -60,7 +60,7 @@ struct rxe_cqe {
|
||||
|
||||
struct rxe_cq {
|
||||
struct ib_cq ibcq;
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
struct rxe_queue *queue;
|
||||
spinlock_t cq_lock;
|
||||
u8 notify;
|
||||
@ -95,7 +95,7 @@ struct rxe_rq {
|
||||
|
||||
struct rxe_srq {
|
||||
struct ib_srq ibsrq;
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
struct rxe_pd *pd;
|
||||
struct rxe_rq rq;
|
||||
u32 srq_num;
|
||||
@ -209,7 +209,7 @@ struct rxe_resp_info {
|
||||
|
||||
struct rxe_qp {
|
||||
struct ib_qp ibqp;
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
struct ib_qp_attr attr;
|
||||
unsigned int valid;
|
||||
unsigned int mtu;
|
||||
@ -309,7 +309,7 @@ static inline int rkey_is_mw(u32 rkey)
|
||||
}
|
||||
|
||||
struct rxe_mr {
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
struct ib_mr ibmr;
|
||||
|
||||
struct ib_umem *umem;
|
||||
@ -342,7 +342,7 @@ enum rxe_mw_state {
|
||||
|
||||
struct rxe_mw {
|
||||
struct ib_mw ibmw;
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
spinlock_t lock;
|
||||
enum rxe_mw_state state;
|
||||
struct rxe_qp *qp; /* Type 2 only */
|
||||
@ -354,7 +354,7 @@ struct rxe_mw {
|
||||
};
|
||||
|
||||
struct rxe_mc_grp {
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
spinlock_t mcg_lock; /* guard group */
|
||||
struct rxe_dev *rxe;
|
||||
struct list_head qp_list;
|
||||
@ -365,7 +365,7 @@ struct rxe_mc_grp {
|
||||
};
|
||||
|
||||
struct rxe_mc_elem {
|
||||
struct rxe_pool_entry pelem;
|
||||
struct rxe_pool_elem elem;
|
||||
struct list_head qp_list;
|
||||
struct list_head grp_list;
|
||||
struct rxe_qp *qp;
|
||||
@ -484,6 +484,6 @@ static inline struct rxe_pd *rxe_mw_pd(struct rxe_mw *mw)
|
||||
|
||||
int rxe_register_device(struct rxe_dev *rxe, const char *ibdev_name);
|
||||
|
||||
void rxe_mc_cleanup(struct rxe_pool_entry *arg);
|
||||
void rxe_mc_cleanup(struct rxe_pool_elem *elem);
|
||||
|
||||
#endif /* RXE_VERBS_H */
|
||||
|
Loading…
x
Reference in New Issue
Block a user