net: hns3: free the ring_data structrue when change tqps
This patch fixes a memory leak problems in change tqps process, the function hns3_uninit_all_ring and hns3_init_all_ring may be called many times. Signed-off-by: Peng Li <lipeng321@huawei.com> Signed-off-by: Mingguang Qu <qumingguang@huawei.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f0e98c97fa
commit
99fdf6b1ca
|
@ -2800,8 +2800,12 @@ int hns3_uninit_all_ring(struct hns3_nic_priv *priv)
|
||||||
h->ae_algo->ops->reset_queue(h, i);
|
h->ae_algo->ops->reset_queue(h, i);
|
||||||
|
|
||||||
hns3_fini_ring(priv->ring_data[i].ring);
|
hns3_fini_ring(priv->ring_data[i].ring);
|
||||||
|
devm_kfree(priv->dev, priv->ring_data[i].ring);
|
||||||
hns3_fini_ring(priv->ring_data[i + h->kinfo.num_tqps].ring);
|
hns3_fini_ring(priv->ring_data[i + h->kinfo.num_tqps].ring);
|
||||||
|
devm_kfree(priv->dev,
|
||||||
|
priv->ring_data[i + h->kinfo.num_tqps].ring);
|
||||||
}
|
}
|
||||||
|
devm_kfree(priv->dev, priv->ring_data);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue