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:45 PM, Luis R.
Rodriguez<lrodriguez@xxxxxxxxxxx> wrote:
> 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,

Oh ok, sorry about that this requires a patch which I thought I had
sent but it seems I didn't:

at76c50x-usb: remove unneeded flush_workqueue() at usb disconnect

Will send.

  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