diff options
author | Andy Grover <andy.grover@oracle.com> | 2010-01-28 01:15:48 +0100 |
---|---|---|
committer | Andy Grover <andy.grover@oracle.com> | 2010-09-09 03:11:57 +0200 |
commit | d0ab25a83c4a08cd98b73a37d3f4c069f7b4f50b (patch) | |
tree | d21dad44f483e684c35209f61b905b53ae582050 /net/rds/message.c | |
parent | RDS: Inline rdma_prepare into cmsg_rdma_args (diff) | |
download | linux-d0ab25a83c4a08cd98b73a37d3f4c069f7b4f50b.tar.xz linux-d0ab25a83c4a08cd98b73a37d3f4c069f7b4f50b.zip |
RDS: purge atomic resources too in rds_message_purge()
Add atomic_free_op function, analogous to rdma_free_op,
and call it in rds_message_purge().
Signed-off-by: Andy Grover <andy.grover@oracle.com>
Diffstat (limited to 'net/rds/message.c')
-rw-r--r-- | net/rds/message.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/net/rds/message.c b/net/rds/message.c index a27e493a63a2..b53306c3e656 100644 --- a/net/rds/message.c +++ b/net/rds/message.c @@ -73,6 +73,11 @@ static void rds_message_purge(struct rds_message *rm) rds_rdma_free_op(&rm->rdma.m_rdma_op); if (rm->rdma.m_rdma_mr) rds_mr_put(rm->rdma.m_rdma_mr); + + if (rm->atomic.op_active) + rds_atomic_free_op(&rm->atomic); + if (rm->atomic.op_rdma_mr) + rds_mr_put(rm->atomic.op_rdma_mr); } void rds_message_put(struct rds_message *rm) |