]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
wifi: brcmfmac: avoid invalid list operation when vendor attach fails
authorArend van Spriel <arend.vanspriel@broadcom.com>
Sat, 6 Jan 2024 10:38:34 +0000 (11:38 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 3 Apr 2024 13:11:06 +0000 (15:11 +0200)
[ Upstream commit b822015a1f57268f5b2ff656736dc4004e7097da ]

When the brcmf_fwvid_attach() fails the driver instance is not added
to the vendor list. Hence we should not try to delete it from that
list when the brcmf_fwvid_detach() function is called in cleanup path.

Cc: stable@vger.kernel.org # 6.2.x
Fixes: d6a5c562214f ("wifi: brcmfmac: add support for vendor-specific firmware api")
Signed-off-by: Arend van Spriel <arend.vanspriel@broadcom.com>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://msgid.link/20240106103835.269149-3-arend.vanspriel@broadcom.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/wireless/broadcom/brcm80211/brcmfmac/fwvid.c

index 86eafdb405419873a1cbb385cb1c4f292408001e..f610818c2b059dd8ab9c53710a0a3dc9e50e18de 100644 (file)
@@ -187,9 +187,10 @@ void brcmf_fwvid_detach_ops(struct brcmf_pub *drvr)
 
        mutex_lock(&fwvid_list_lock);
 
-       drvr->vops = NULL;
-       list_del(&drvr->bus_if->list);
-
+       if (drvr->vops) {
+               drvr->vops = NULL;
+               list_del(&drvr->bus_if->list);
+       }
        mutex_unlock(&fwvid_list_lock);
 }