[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <d6520e83-68d4-1c32-5291-74163b74e249@microchip.com>
Date: Wed, 12 Sep 2018 10:43:46 +0300
From: Claudiu Beznea <Claudiu.Beznea@...rochip.com>
To: Colin King <colin.king@...onical.com>,
Aditya Shankar <aditya.shankar@...rochip.com>,
Ganesh Krishna <ganesh.krishna@...rochip.com>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
<linux-wireless@...r.kernel.org>, <devel@...verdev.osuosl.org>
CC: <kernel-janitors@...r.kernel.org>, <linux-kernel@...r.kernel.org>
Subject: Re: [PATCH] staging: wilc1000: fix null checks on wilc
On 11.09.2018 20:38, Colin King wrote:
> From: Colin Ian King <colin.king@...onical.com>
>
> Currently the pointer wilc is being null checked several times
> and yet not checked for the final workqueue flush and destroy
> (which can lead to a null pointer dereference if wilc is null);
> these missing null checks were overlooked in an earlier core
> refactoring commit.
>
> Clean up the code by checking wilc at the start and bailing out
> early if it is null allowing the subsequent null checks to be
> removed, this also fixes the potential null pointer deferences
> on the workqueue flush and destroy calls.
>
> Detected by CoverityScan, CID#1473305 ("Dereference after null check")
>
> Fixes: b3ee105c332e ("staging: wilc1000: refactor code to move initilization in wilc_netdev_init()")
> Signed-off-by: Colin Ian King <colin.king@...onical.com>
Reviewed-by: Claudiu Beznea <claudiu.beznea@...rochip.com>
> ---
> drivers/staging/wilc1000/linux_wlan.c | 9 ++++++---
> 1 file changed, 6 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/staging/wilc1000/linux_wlan.c b/drivers/staging/wilc1000/linux_wlan.c
> index a498321c908b..49afda669393 100644
> --- a/drivers/staging/wilc1000/linux_wlan.c
> +++ b/drivers/staging/wilc1000/linux_wlan.c
> @@ -1015,15 +1015,18 @@ void wilc_netdev_cleanup(struct wilc *wilc)
> {
> int i;
>
> - if (wilc && (wilc->vif[0]->ndev || wilc->vif[1]->ndev))
> + if (!wilc)
> + return;
> +
> + if (wilc->vif[0]->ndev || wilc->vif[1]->ndev)
> unregister_inetaddr_notifier(&g_dev_notifier);
>
> - if (wilc && wilc->firmware) {
> + if (wilc->firmware) {
> release_firmware(wilc->firmware);
> wilc->firmware = NULL;
> }
>
> - if (wilc && (wilc->vif[0]->ndev || wilc->vif[1]->ndev)) {
> + if (wilc->vif[0]->ndev || wilc->vif[1]->ndev) {
> for (i = 0; i < NUM_CONCURRENT_IFC; i++)
> if (wilc->vif[i]->ndev)
> if (wilc->vif[i]->mac_opened)
>
Powered by blists - more mailing lists