提交 3ebbabea 编写于 作者: T Tony Lindgren 提交者: Kalle Valo

wlcore: Fix misplaced PM call for scan_complete_work()

With runtime PM enabled, we now need to have wlcore enabled longer
until after we're done calling wlcore_cmd_regdomain_config_locked():

scan_complete_work()
 wlcore_cmd_regdomain_config_locked()
   wlcore_cmd_send_failsafe()
     wl12xx_sdio_raw_read()

Note that this is not needed before runtime PM support as the
custom PM code had it's own timer. We have not yet enabled runtime
PM autosuspend for wlcore and this is why this issue now shows up.

Let's fix the issues first before we enable runtime PM autosuspend.
Signed-off-by: NTony Lindgren <tony@atomide.com>
Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
上级 fa2648a3
...@@ -78,8 +78,6 @@ void wl1271_scan_complete_work(struct work_struct *work) ...@@ -78,8 +78,6 @@ void wl1271_scan_complete_work(struct work_struct *work)
wl1271_cmd_build_ap_probe_req(wl, wlvif, wlvif->probereq); wl1271_cmd_build_ap_probe_req(wl, wlvif, wlvif->probereq);
} }
pm_runtime_put(wl->dev);
if (wl->scan.failed) { if (wl->scan.failed) {
wl1271_info("Scan completed due to error."); wl1271_info("Scan completed due to error.");
wl12xx_queue_recovery_work(wl); wl12xx_queue_recovery_work(wl);
...@@ -87,6 +85,8 @@ void wl1271_scan_complete_work(struct work_struct *work) ...@@ -87,6 +85,8 @@ void wl1271_scan_complete_work(struct work_struct *work)
wlcore_cmd_regdomain_config_locked(wl); wlcore_cmd_regdomain_config_locked(wl);
pm_runtime_put(wl->dev);
ieee80211_scan_completed(wl->hw, &info); ieee80211_scan_completed(wl->hw, &info);
out: out:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册