From: Jérôme Pouiller Date: Fri, 15 May 2020 08:33:22 +0000 (+0200) Subject: staging: wfx: fix error reporting in wfx_start_ap() X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=a1ae4d07fd94da1b3f7597f1594af2e35f1065cc;p=linux.git staging: wfx: fix error reporting in wfx_start_ap() If AP did not start, the error was not reported to mac80211. Signed-off-by: Jérôme Pouiller Link: https://lore.kernel.org/r/20200515083325.378539-17-Jerome.Pouiller@silabs.com Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/staging/wfx/sta.c b/drivers/staging/wfx/sta.c index 57304ed42e794..f448957c1a928 100644 --- a/drivers/staging/wfx/sta.c +++ b/drivers/staging/wfx/sta.c @@ -476,14 +476,17 @@ int wfx_start_ap(struct ieee80211_hw *hw, struct ieee80211_vif *vif) { struct wfx_vif *wvif = (struct wfx_vif *)vif->drv_priv; struct wfx_dev *wdev = wvif->wdev; + int ret; wvif = NULL; while ((wvif = wvif_iterate(wdev, wvif)) != NULL) wfx_update_pm(wvif); wvif = (struct wfx_vif *)vif->drv_priv; wfx_upload_ap_templates(wvif); - hif_start(wvif, &vif->bss_conf, wvif->channel); - return 0; + ret = hif_start(wvif, &vif->bss_conf, wvif->channel); + if (ret > 0) + return -EIO; + return ret; } void wfx_stop_ap(struct ieee80211_hw *hw, struct ieee80211_vif *vif)