diff options
author | Ben <ben.rosenfeld@intel.com> | 2015-03-12 09:37:34 -0400 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2015-03-17 11:02:42 +0100 |
commit | 2e54a6895e3e0cada8d194ace4f5baae643a073f (patch) | |
tree | f12959a49465da789bc6095c7ccbc08b28a67e3c /net/wireless/reg.c | |
parent | c23e31cf7b55e4d2e462b61dadb4c2d9538d3781 (diff) |
cfg80211: Process all pending regulatory requests/hints
It is possible that there are several regulatory requests
pending, but the processing of the last one does not call
CRDA, and thus the other requests are not handled.
Fix this by rescheduling the work until all requests have
been processed.
Signed-off-by: Ben Rosenfeld <ben.rosenfeld@intel.com>
Signed-off-by: Ilan Peer <ilan.peer@intel.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/wireless/reg.c')
-rw-r--r-- | net/wireless/reg.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/net/wireless/reg.c b/net/wireless/reg.c index d8671036c264..8c6cf52b9f1d 100644 --- a/net/wireless/reg.c +++ b/net/wireless/reg.c @@ -2159,6 +2159,13 @@ static void reg_process_pending_hints(void) } reg_process_hint(reg_request); + + lr = get_last_request(); + + spin_lock(®_requests_lock); + if (!list_empty(®_requests_list) && lr && lr->processed) + schedule_work(®_work); + spin_unlock(®_requests_lock); } /* Processes beacon hints -- this has nothing to do with country IEs */ |