Search Linux Wireless

Re: [PATCH v3] mac80211: redefine usage of the mac80211 workqueue

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Jul 29, 2009 at 1:00 PM, John W. Linville<linville@xxxxxxxxxxxxx> wrote:
> On Mon, Jul 27, 2009 at 03:21:31PM -0700, Luis R. Rodriguez wrote:
>> The mac80211 workqueue exists to enable mac80211 and drivers
>> to queue their own work on a single threaded workqueue. mac80211
>> takes care to flush the workqueue during suspend but we never
>> really had requirements on drivers for how they should use
>> the workqueue in consideration for suspend.
>>
>> We extend mac80211 to document how the mac80211 workqueue should
>> be used, how it should not be used and finally move raw access to
>> the workqueue to mac80211 only. Drivers and mac80211 use helpers
>> to queue work onto the mac80211 workqueue:
>>
>>   * ieee80211_queue_work()
>>   * ieee80211_queue_delayed_work()
>>
>> These helpers will now warn if mac80211 already completed its
>> suspend cycle and someone is trying to queue work. mac80211
>> flushes the mac80211 workqueue prior to suspend a few times,
>> but we haven't taken the care to ensure drivers won't add more
>> work after suspend. To help with this we add a warning when
>> someone tries to add work and mac80211 already completed the
>> suspend cycle.
>>
>> Drivers should ensure they cancel any work or delayed work
>> in the mac80211 stop() callback.
>
> How are they supposed to do that after you've removed workqueue
> from the ieee80211_hw structure?

They do not refer to the mac80211 workqueue for that, they can cancel
work using cancel_work_sync(their_foo_work_struct).

> This breaks the compilation of
> at76c50x-usb.c...

Strange, I thought I tested that, will retest,

  Luis
--
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux