mac80211_hwsim: fix PS debugfs file locking
The functions called within the iterators must be called with tasklets disabled, so use atomic iteration like the rest of the code and disable tasklets around the whole operation. Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
parent
79c892b850
commit
a809ca5e03
@ -626,22 +626,22 @@ static int hwsim_fops_ps_write(void *dat, u64 val)
|
|||||||
old_ps = data->ps;
|
old_ps = data->ps;
|
||||||
data->ps = val;
|
data->ps = val;
|
||||||
|
|
||||||
|
local_bh_disable();
|
||||||
if (val == PS_MANUAL_POLL) {
|
if (val == PS_MANUAL_POLL) {
|
||||||
ieee80211_iterate_active_interfaces(data->hw,
|
ieee80211_iterate_active_interfaces_atomic(
|
||||||
IEEE80211_IFACE_ITER_NORMAL,
|
data->hw, IEEE80211_IFACE_ITER_NORMAL,
|
||||||
hwsim_send_ps_poll, data);
|
hwsim_send_ps_poll, data);
|
||||||
data->ps_poll_pending = true;
|
data->ps_poll_pending = true;
|
||||||
} else if (old_ps == PS_DISABLED && val != PS_DISABLED) {
|
} else if (old_ps == PS_DISABLED && val != PS_DISABLED) {
|
||||||
ieee80211_iterate_active_interfaces(data->hw,
|
ieee80211_iterate_active_interfaces_atomic(
|
||||||
IEEE80211_IFACE_ITER_NORMAL,
|
data->hw, IEEE80211_IFACE_ITER_NORMAL,
|
||||||
hwsim_send_nullfunc_ps,
|
hwsim_send_nullfunc_ps, data);
|
||||||
data);
|
|
||||||
} else if (old_ps != PS_DISABLED && val == PS_DISABLED) {
|
} else if (old_ps != PS_DISABLED && val == PS_DISABLED) {
|
||||||
ieee80211_iterate_active_interfaces(data->hw,
|
ieee80211_iterate_active_interfaces_atomic(
|
||||||
IEEE80211_IFACE_ITER_NORMAL,
|
data->hw, IEEE80211_IFACE_ITER_NORMAL,
|
||||||
hwsim_send_nullfunc_no_ps,
|
hwsim_send_nullfunc_no_ps, data);
|
||||||
data);
|
|
||||||
}
|
}
|
||||||
|
local_bh_enable();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user