]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/commitdiff
ath10k: Fix error handling in case of CE pipe init failure
authorRakesh Pillai <pillair@codeaurora.org>
Fri, 11 Dec 2020 19:00:10 +0000 (00:30 +0530)
committerKleber Sacilotto de Souza <kleber.souza@canonical.com>
Wed, 14 Apr 2021 16:31:21 +0000 (18:31 +0200)
BugLink: https://bugs.launchpad.net/bugs/1918974
[ Upstream commit 31561e8557cd1eeba5806ac9ce820f8323b2201b ]

Currently if the copy engine pipe init fails for snoc based
chipsets, the rri is not freed.

Fix this error handling for copy engine pipe init
failure.

Tested-on: WCN3990 hw1.0 SNOC WLAN.HL.3.1-01040-QCAHLSWMTPLZ-1

Fixes: 4945af5b264f ("ath10k: enable SRRI/DRRI support on ddr for WCN3990")
Signed-off-by: Rakesh Pillai <pillair@codeaurora.org>
Reviewed-by: Brian Norris <briannorris@chromium.org>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
Link: https://lore.kernel.org/r/1607713210-18320-1-git-send-email-pillair@codeaurora.org
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Kelsey Skunberg <kelsey.skunberg@canonical.com>
drivers/net/wireless/ath/ath10k/snoc.c

index 63607c3b8e818eaeea40d9596b20fe49320c2d76..d4589b2ab3b6dddd960ca822363c513d63dd7acc 100644 (file)
@@ -1039,12 +1039,13 @@ static int ath10k_snoc_hif_power_up(struct ath10k *ar,
        ret = ath10k_snoc_init_pipes(ar);
        if (ret) {
                ath10k_err(ar, "failed to initialize CE: %d\n", ret);
-               goto err_wlan_enable;
+               goto err_free_rri;
        }
 
        return 0;
 
-err_wlan_enable:
+err_free_rri:
+       ath10k_ce_free_rri(ar);
        ath10k_snoc_wlan_disable(ar);
 
        return ret;