Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp365986pxk; Thu, 17 Sep 2020 05:21:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxGfoUvtgpo644Jrv/GCb6k9V/Q6ZgLNt/Hetz6W7dqnBNoqbIvITl8OkXbb8OxXSufd3iH X-Received: by 2002:a17:906:270f:: with SMTP id z15mr19446221ejc.6.1600345315860; Thu, 17 Sep 2020 05:21:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600345315; cv=none; d=google.com; s=arc-20160816; b=ea5xFKkj9OXrdqqwb5+gWIJFk1aK8aURiCnuuadNeS5IpfPEAyn3hRLAWtx3m+EJOp /JKRwx/UrQQIqczdRStq0AfdMps7Zl0SbX4YrTLsHI4lqebVysg/kQp3zCw7RbWJE6Gx 4O5j4h7AKxEB5cvtTaAKO/ie99MLpzX9SKvxg9Mump0IOFqLBA2M7g0DDjEMb9rH1ZuY vbFQSP+HCR/MLKk0hip2QB+9I9Qr6dcURF3QYTYU80ZMIHXZHZ1XCe22m6YsPRle7Wfb 7nA/CctP+nSs5Pul6YdEcU6LDI5aUX+CmDf6A5qzNPXd+zrrfaqv5wno9217Xz1TQB9r AThQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=MvnJrb4Zegywz6Ehy78j9lhCeH9JGebCOeGmmcAUIkQ=; b=P64aUyDKyqdGFDPDHpk9/kqQU1v+XuwxvJOOMPK0uIDCuuLrcQDlZ6FT8XD1q47npv f1sTNkCT7iFtznmu7+19gaDH6AMjxOOlejXN4usNtEbcjlAZZmeyoqP3+EEPYSveRZrQ JcB362gl+LRWJ37gS3ZvgLH9trIHtdmOPbTd3f2F5sbxOKXAIiGXr2R6deLbgLdX4jc4 tS0AXXg864UltT83zqUj5HHJtwHkXKzhpaVV+ioYOLhYmZZP7Fw9Y2+B8iAXQkOvhP6S kayzd0ZaUBQNo1fKoQZ/xt65ByZWb17yWWW3fzQYjboq4v1uNlviRTmnENzMHq1TV/BH mCng== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bs11si14167082edb.90.2020.09.17.05.21.32; Thu, 17 Sep 2020 05:21:55 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726908AbgIQMUT (ORCPT + 99 others); Thu, 17 Sep 2020 08:20:19 -0400 Received: from szxga06-in.huawei.com ([45.249.212.32]:37994 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726952AbgIQMUC (ORCPT ); Thu, 17 Sep 2020 08:20:02 -0400 Received: from DGGEMS411-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id EFCE8EDA883CF9A60A83; Thu, 17 Sep 2020 20:19:57 +0800 (CST) Received: from huawei.com (10.175.104.82) by DGGEMS411-HUB.china.huawei.com (10.3.19.211) with Microsoft SMTP Server id 14.3.487.0; Thu, 17 Sep 2020 20:19:54 +0800 From: Huang Guobin To: , , , , , CC: , , Subject: [PATCH net] net: wilc1000: clean up resource in error path of init mon interface Date: Thu, 17 Sep 2020 08:30:19 -0400 Message-ID: <20200917123019.206382-1-huangguobin4@huawei.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.104.82] X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org The wilc_wfi_init_mon_int() forgets to clean up resource when register_netdevice() failed. Add the missed call to fix it. And the return value of netdev_priv can't be NULL, so remove the unnecessary error handling. Fixes: 588713006ea4 ("staging: wilc1000: avoid the use of 'wilc_wfi_mon' static variable") Reported-by: Hulk Robot Signed-off-by: Huang Guobin --- drivers/net/wireless/microchip/wilc1000/mon.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/drivers/net/wireless/microchip/wilc1000/mon.c b/drivers/net/wireless/microchip/wilc1000/mon.c index 358ac8601333..b5a1b65c087c 100644 --- a/drivers/net/wireless/microchip/wilc1000/mon.c +++ b/drivers/net/wireless/microchip/wilc1000/mon.c @@ -235,11 +235,10 @@ struct net_device *wilc_wfi_init_mon_interface(struct wilc *wl, if (register_netdevice(wl->monitor_dev)) { netdev_err(real_dev, "register_netdevice failed\n"); + free_netdev(wl->monitor_dev); return NULL; } priv = netdev_priv(wl->monitor_dev); - if (!priv) - return NULL; priv->real_ndev = real_dev; -- 2.25.1