mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 06:43:09 +00:00
dccp: fix a memleak for dccp_feat_init err process
In dccp_feat_init, when ccid_get_builtin_ccids failsto alloc memory for rx.val, it should free tx.val before returning an error. Signed-off-by: Xin Long <lucien.xin@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
b7953d3c0e
commit
e90ce2fc27
@ -1471,9 +1471,12 @@ int dccp_feat_init(struct sock *sk)
|
||||
* singleton values (which always leads to failure).
|
||||
* These settings can still (later) be overridden via sockopts.
|
||||
*/
|
||||
if (ccid_get_builtin_ccids(&tx.val, &tx.len) ||
|
||||
ccid_get_builtin_ccids(&rx.val, &rx.len))
|
||||
if (ccid_get_builtin_ccids(&tx.val, &tx.len))
|
||||
return -ENOBUFS;
|
||||
if (ccid_get_builtin_ccids(&rx.val, &rx.len)) {
|
||||
kfree(tx.val);
|
||||
return -ENOBUFS;
|
||||
}
|
||||
|
||||
if (!dccp_feat_prefer(sysctl_dccp_tx_ccid, tx.val, tx.len) ||
|
||||
!dccp_feat_prefer(sysctl_dccp_rx_ccid, rx.val, rx.len))
|
||||
|
Loading…
Reference in New Issue
Block a user