IB/rdmavt,hfi1,qib: Fix memory leak
rdi->ports has memory allocated in rvt_alloc_device(), but does not get freed because the hfi1 and qib drivers drivers call ib_dealloc_device() directly instead of going through rdmavt. Add a rvt_dealloc_device() that frees rdi->ports and then calls ib_dealloc_device(). Switch hfi1 and qib drivers to calling rvt_dealloc_device() instead of ib_dealloc_device() directly. Reviewed-by: Dennis Dalessandro <dennis.dalessandro@intel.com> Reviewed-by: Brian Welty <brian.welty@intel.com> Signed-off-by: Jubin John <jubin.john@intel.com> Reviewed-by: Leon Romanovsky <leonro@mellanox.com> Signed-off-by: Doug Ledford <dledford@redhat.com>
This commit is contained in:
@@ -106,6 +106,19 @@ struct rvt_dev_info *rvt_alloc_device(size_t size, int nports)
|
||||
}
|
||||
EXPORT_SYMBOL(rvt_alloc_device);
|
||||
|
||||
/**
|
||||
* rvt_dealloc_device - deallocate rdi
|
||||
* @rdi: structure to free
|
||||
*
|
||||
* Free a structure allocated with rvt_alloc_device()
|
||||
*/
|
||||
void rvt_dealloc_device(struct rvt_dev_info *rdi)
|
||||
{
|
||||
kfree(rdi->ports);
|
||||
ib_dealloc_device(&rdi->ibdev);
|
||||
}
|
||||
EXPORT_SYMBOL(rvt_dealloc_device);
|
||||
|
||||
static int rvt_query_device(struct ib_device *ibdev,
|
||||
struct ib_device_attr *props,
|
||||
struct ib_udata *uhw)
|
||||
|
Reference in New Issue
Block a user