From: Sabrina Dubroca Date: Fri, 22 Apr 2016 09:28:07 +0000 (+0200) Subject: macsec: fix SA leak if initialization fails X-Git-Tag: v4.1.12-92~24^2~72 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=a377a47ed55b2db0009a4dc15b501f960b2cd478;p=users%2Fjedix%2Flinux-maple.git macsec: fix SA leak if initialization fails Fixes: c09440f7dcb3 ("macsec: introduce IEEE 802.1AE driver") Reported-by: Lance Richardson Signed-off-by: Sabrina Dubroca Acked-by: Hannes Frederic Sowa Signed-off-by: David S. Miller (cherry picked from commit 38787fc209580f9b5918e93e71da7c960dbb5d8d) Orabug: 24614549 Signed-off-by: Ethan Zhao Signed-off-by: Dhaval Giani --- diff --git a/drivers/net/macsec.c b/drivers/net/macsec.c index 742a65d727800..857b07508d66d 100644 --- a/drivers/net/macsec.c +++ b/drivers/net/macsec.c @@ -1627,6 +1627,7 @@ static int macsec_add_rxsa(struct sk_buff *skb, struct genl_info *info) rx_sa = kmalloc(sizeof(*rx_sa), GFP_KERNEL); if (!rx_sa || init_rx_sa(rx_sa, nla_data(tb_sa[MACSEC_SA_ATTR_KEY]), secy->key_len, secy->icv_len)) { + kfree(rx_sa); rtnl_unlock(); return -ENOMEM; } @@ -1771,6 +1772,7 @@ static int macsec_add_txsa(struct sk_buff *skb, struct genl_info *info) tx_sa = kmalloc(sizeof(*tx_sa), GFP_KERNEL); if (!tx_sa || init_tx_sa(tx_sa, nla_data(tb_sa[MACSEC_SA_ATTR_KEY]), secy->key_len, secy->icv_len)) { + kfree(tx_sa); rtnl_unlock(); return -ENOMEM; }