diff options
author | Johannes Berg <johannes@sipsolutions.net> | 2009-08-18 13:51:57 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-08-20 11:36:05 -0400 |
commit | ad002395fd230528281083f4be71855ed7e35b04 (patch) | |
tree | c2bccce17ad69dcfb454fe3a38ba68f0f210b5b5 /net/wireless/core.h | |
parent | 21f8a73f829797eb7ebc12202b4c68e10e751ddb (diff) |
cfg80211: fix dangling scan request checking
My patch "cfg80211: fix deadlock" broke the code it
was supposed to fix, the scan request checking. But
it's not trivial to put it back the way it was, since
the original patch had a deadlock.
Now do it in a completely new way: queue the check
off to a work struct, where we can freely lock. But
that has some more complications, like needing to
wait for it to be done before the wiphy/rdev can be
destroyed, so some code is required to handle that.
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/wireless/core.h')
-rw-r--r-- | net/wireless/core.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/net/wireless/core.h b/net/wireless/core.h index c603f5286326..f565432ae22f 100644 --- a/net/wireless/core.h +++ b/net/wireless/core.h | |||
@@ -50,6 +50,8 @@ struct cfg80211_registered_device { | |||
50 | struct mutex devlist_mtx; | 50 | struct mutex devlist_mtx; |
51 | struct list_head netdev_list; | 51 | struct list_head netdev_list; |
52 | int devlist_generation; | 52 | int devlist_generation; |
53 | int opencount; /* also protected by devlist_mtx */ | ||
54 | wait_queue_head_t dev_wait; | ||
53 | 55 | ||
54 | /* BSSes/scanning */ | 56 | /* BSSes/scanning */ |
55 | spinlock_t bss_lock; | 57 | spinlock_t bss_lock; |