Re: [PATCH v3 net 4/4] pds_core: make wait_context part of q_info
From: Jacob Keller
Date: Wed Apr 16 2025 - 16:17:16 EST
On 4/15/2025 4:29 PM, Shannon Nelson wrote:
> Make the wait_context a full part of the q_info struct rather
> than a stack variable that goes away after pdsc_adminq_post()
> is done so that the context is still available after the wait
> loop has given up.
>
> There was a case where a slow development firmware caused
> the adminq request to time out, but then later the FW finally
> finished the request and sent the interrupt. The handler tried
> to complete_all() the completion context that had been created
> on the stack in pdsc_adminq_post() but no longer existed.
> This caused bad pointer usage, kernel crashes, and much wailing
> and gnashing of teeth.
Ugh, I can imagine that was hard to track down..
>
> Fixes: 01ba61b55b20 ("pds_core: Add adminq processing and commands")
> Reviewed-by: Simon Horman <horms@xxxxxxxxxx>
> Signed-off-by: Shannon Nelson <shannon.nelson@xxxxxxx>
> ---
Yea, this approach seems a bit cleaner overall too!
Reviewed-by: Jacob Keller <jacob.e.keller@xxxxxxxxx>