IB/qib: Replace rcu_assign_pointer() with RCU_INIT_POINTER() in qib_keys.c
The uses of "rcu_assign_pointer()" are NULLing out the pointers. According to RCU_INIT_POINTER()'s block comment: "1. This use of RCU_INIT_POINTER() is NULLing out the pointer" it is better to use it instead of rcu_assign_pointer() because it has a smaller overhead. The following Coccinelle semantic patch was used: @@ @@ - rcu_assign_pointer + RCU_INIT_POINTER (..., NULL) [Derived from http://marc.info/?l=linux-rdma&m=140836519219236&w=2] Tested-by: Mike Marciniszyn <mike.marciniszyn@intel.com> Signed-off-by: Andreea-Cristina Bernat <bernat.ada@gmail.com> Signed-off-by: Mike Marciniszyn <mike.marciniszyn@intel.com> Signed-off-by: Roland Dreier <roland@purestorage.com>
This commit is contained in:
parent
03c885913f
commit
590c3fec2d
|
@ -122,10 +122,10 @@ void qib_free_lkey(struct qib_mregion *mr)
|
||||||
if (!mr->lkey_published)
|
if (!mr->lkey_published)
|
||||||
goto out;
|
goto out;
|
||||||
if (lkey == 0)
|
if (lkey == 0)
|
||||||
rcu_assign_pointer(dev->dma_mr, NULL);
|
RCU_INIT_POINTER(dev->dma_mr, NULL);
|
||||||
else {
|
else {
|
||||||
r = lkey >> (32 - ib_qib_lkey_table_size);
|
r = lkey >> (32 - ib_qib_lkey_table_size);
|
||||||
rcu_assign_pointer(rkt->table[r], NULL);
|
RCU_INIT_POINTER(rkt->table[r], NULL);
|
||||||
}
|
}
|
||||||
qib_put_mr(mr);
|
qib_put_mr(mr);
|
||||||
mr->lkey_published = 0;
|
mr->lkey_published = 0;
|
||||||
|
|
Loading…
Reference in New Issue