There are two error paths which are missing unlocks in this function.

Fixes: 955dc68cb9b2 ("net/ncsi: Add generic netlink family")
Signed-off-by: Dan Carpenter <dan.carpen...@oracle.com>

diff --git a/net/ncsi/ncsi-netlink.c b/net/ncsi/ncsi-netlink.c
index b73239b76349..05fcfb4fbe1d 100644
--- a/net/ncsi/ncsi-netlink.c
+++ b/net/ncsi/ncsi-netlink.c
@@ -299,6 +299,7 @@ static int ncsi_set_interface_nl(struct sk_buff *msg, 
struct genl_info *info)
                        package = np;
        if (!package) {
                /* The user has set a package that does not exist */
+               spin_unlock_irqrestore(&ndp->lock, flags);
                return -ERANGE;
        }
 
@@ -317,6 +318,7 @@ static int ncsi_set_interface_nl(struct sk_buff *msg, 
struct genl_info *info)
                /* The user has set a channel that does not exist on this
                 * package
                 */
+               spin_unlock_irqrestore(&ndp->lock, flags);
                netdev_info(ndp->ndev.dev, "NCSI: Channel %u does not exist!\n",
                            channel_id);
                return -ERANGE;

Reply via email to