Search Linux Wireless

Re: [PATCH] mac80211: Fix deadlock in ieee80211_do_stop.

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

 



Hey, Johannes.

On 11/16/2010 06:40 PM, Johannes Berg wrote:
> On Tue, 2010-11-16 at 15:19 +0100, Tejun Heo wrote:
> 
>> 3. What if you replace it with the following?
>>
>>    alloc_workqueue(wiphy_name(local->hw.wiphy), WQ_NON_REENTRANT, 0)
> 
> Wait ... what's the difference between this and
> alloc_ordered_workqueue() then?

alloc_ordered_workqueue() is fully ordered.  ie. Works are executed in
the queued order regardless of where it's queued, which also implies
that there is only one work in progress at any given time.

WQ_NON_REENTRANT doesn't guarantee ordered execution but it guarantees
that a single work is not executed concurrently on multiple CPUs.  I'm
not sure whether this would be safe for the workqueue used by mac80211
but it should let us know whether the workqueue is choked due to a
work which is executing for long time.  In the long run, if using non
reentrant is safe for mac80211, using it would be much better.

Thanks.

-- 
tejun
--
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