IB/srp: Fix a memory descriptor leak in an error path
authorBart Van Assche <bart.vanassche@sandisk.com>
Thu, 12 May 2016 17:48:13 +0000 (10:48 -0700)
committerDoug Ledford <dledford@redhat.com>
Fri, 13 May 2016 17:37:21 +0000 (13:37 -0400)
commit9d8e7d0dacf09ddac7e617d17dbeec6af56e81e8
treee94611ab63aeeafd2fae69089178d136a9bb5cfa
parentcf1acab7d75652a372ee5b9c996689d518914e83
IB/srp: Fix a memory descriptor leak in an error path

If an error occurs after srp_fr_pool_get() succeeded and before the
descriptor is stored in srp_map_state (*state->fr.next++ = desc)
then srp_unmap_data() won't free the newly allocated memory
descriptor. Hence free the descriptor explicitly.

Fixes: f7f7aab1a5c0 ("IB/srp: Convert to new registration API")
Signed-off-by: Bart Van Assche <bart.vanassche@sandisk.com>
Tested-by: Laurence Oberman <loberman@redhat.com>
Cc: Sagi Grimberg <sai@grimberg.me>
Cc: Christoph Hellwig <hch@lst.de>
Cc: <stable@vger.kernel.org> # v4.4+
Signed-off-by: Doug Ledford <dledford@redhat.com>
drivers/infiniband/ulp/srp/ib_srp.c