* one fix for rfkill while scheduled scan is running.
Linus's system hit this issue. WiFi would be unavailable after this has happpened because of bad state in cfg80211. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJUvBLgAAoJEC0Llv5uNjIBn60QAJlN62JnZu5X6XCnzK8hdTe3 4AFKf9e+ejBDEfFTcGLA+fX0fDgCaWkY5kYmS0jlqd60u7BUUOENxJGgv1FRGcqr fIjN8nfjbr5p6FZk6E+sVvDgs4NJ+tosnZofxwBOflVK9cAON01MsV/SuUHh9A8i qBVn9aZHbpjSNPSOIjZgvcOTREE0ckHVYJEpAlR0IXYUKRxY3+XtpmruSnoNNnox XKljOQRzMR/LwTIX1De4Uw09NDjWL+u5KpZNuXmaG6Z/4HoKDlqN+ZTJtxSGXo8m F6VkTXQPmZc9+7ELzMYn5o5CDaEGejCVxMP7AhYzztCDwrmV0cGMb6wKcJFMbE8M l+8VikOGtEnbAWh+vfLyKsB0hMb5SBjxxh2Vu3xpglOLinZKHwdJPAweoCwRgp8Y u+Ra21u+giJPeyMTVnzTVO4M0TQ6UuvVP7Zreq51TXaLYrQzObDf+JtRROQMm84k llhQ9dwSznVZ7Ub1cYh0wbJ7FVDV7RT0fSbmtmHY9LBSPffdigvZtzVMEYM+kbDm 72Rqjd/2JqYCvFJpj6j6bpOZUdfT5pmq30eknyGY22wChgC3rkNp2TKHRfVOq2lK kSLTgzCAXhI21/UWbSwyKft5w/3u7RdFFNdaZA7KQTgAGYQESf9EHaPq3o+/hlRy ofJWo4B2ctiiKl2IC1uW =WBj6 -----END PGP SIGNATURE----- Merge tag 'iwlwifi-for-kalle-2015-01-15' of https://git.kernel.org/pub/scm/linux/kernel/git/iwlwifi/iwlwifi-fixes * one fix for rfkill while scheduled scan is running. Linus's system hit this issue. WiFi would be unavailable after this has happpened because of bad state in cfg80211.
This commit is contained in:
commit
7b05520160
@ -1107,6 +1107,12 @@ int iwl_mvm_scan_offload_stop(struct iwl_mvm *mvm, bool notify)
|
|||||||
return iwl_umac_scan_stop(mvm, IWL_UMAC_SCAN_UID_SCHED_SCAN,
|
return iwl_umac_scan_stop(mvm, IWL_UMAC_SCAN_UID_SCHED_SCAN,
|
||||||
notify);
|
notify);
|
||||||
|
|
||||||
|
if (mvm->scan_status == IWL_MVM_SCAN_NONE)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (iwl_mvm_is_radio_killed(mvm))
|
||||||
|
goto out;
|
||||||
|
|
||||||
if (mvm->scan_status != IWL_MVM_SCAN_SCHED &&
|
if (mvm->scan_status != IWL_MVM_SCAN_SCHED &&
|
||||||
(!(mvm->fw->ucode_capa.api[0] & IWL_UCODE_TLV_API_LMAC_SCAN) ||
|
(!(mvm->fw->ucode_capa.api[0] & IWL_UCODE_TLV_API_LMAC_SCAN) ||
|
||||||
mvm->scan_status != IWL_MVM_SCAN_OS)) {
|
mvm->scan_status != IWL_MVM_SCAN_OS)) {
|
||||||
@ -1143,6 +1149,7 @@ int iwl_mvm_scan_offload_stop(struct iwl_mvm *mvm, bool notify)
|
|||||||
if (mvm->scan_status == IWL_MVM_SCAN_OS)
|
if (mvm->scan_status == IWL_MVM_SCAN_OS)
|
||||||
iwl_mvm_unref(mvm, IWL_MVM_REF_SCAN);
|
iwl_mvm_unref(mvm, IWL_MVM_REF_SCAN);
|
||||||
|
|
||||||
|
out:
|
||||||
mvm->scan_status = IWL_MVM_SCAN_NONE;
|
mvm->scan_status = IWL_MVM_SCAN_NONE;
|
||||||
|
|
||||||
if (notify) {
|
if (notify) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user