Re: [PATCH net-next 4/6] net: ipa: ensure hardware has power in ipa_start_xmit()
From: Alex Elder
Date: Mon Aug 16 2021 - 13:56:46 EST
On 8/16/21 9:20 AM, Alex Elder wrote:
On 8/16/21 9:15 AM, Jakub Kicinski wrote:
On Fri, 13 Aug 2021 21:25:23 -0500 Alex Elder wrote:
This is racy, what if the pm work gets scheduled on another CPU and
calls wake right here (i.e. before you call netif_stop_queue())?
The queue may never get woken up?
I haven't been seeing this happen but I think you may be right.
I did think about this race, but I think I was relying on the
PM work queue to somehow avoid the problem. I need to think
about this again after a good night's sleep. I might need
to add an atomic flag or something.
Maybe add a spin lock? Seems like the whole wake up path will be
expensive enough for a spin lock to be in the noise. You can always
add complexity later.
Exactly what I just decided after trying to work out a
clever way without using a spinlock... I'll be sending
out a fix today. Thanks.
I'm finding this isn't an easy problem to solve (or even think
about). While I ponder the best course of action I'm going
to send out another series (i.e., *before* I send a fix for
this issue) because I'd like to get everything I have out
for review this week. I *will* address this potential race
one way or another, possibly later today.
-Alex
-Alex