On Nov 29 20:59, Takashi Yano wrote:
> Previously, the sig thread ran in THREAD_PRIORITY_HIGHEST priority.
> This causes a critical delay in the signal handling in the main
> thread if too many signals are received rapidly and the CPU is very
> busy. In this case, most of the CPU time is allocated to the sig
> thread, so the main thread cannot have a chance of handling signals.
> With this patch, to avoid such a situation, the priority of the sig
> thread is set to THREAD_PRIORITY_NORMAL priority. Furthermore, if
> the signal is alerted to the main thread, but the main thread does
> not handle it yet, to increase the chance of handling it in the main
> thread, reduce the sig thread priority to THREAD_PRIORITY_LOWEST
> priority temporarily before calling _cygtls::handle_SIGCONT().
> 
> Addresses: https://cygwin.com/pipermail/cygwin/2024-November/256744.html
> Fixes: 53ad6f1394aa ("(cygthread::cygthread): Use three only arguments for 
> detached threads, and start the thread via QueueUserAPC/async_create.")
> Reported-by: Christian Franke <christian.fra...@t-online.de>
> Reviewed-by: Corinna Vinschen <cori...@vinschen.de>
> Signed-off-by: Takashi Yano <takashi.y...@nifty.ne.jp>
> ---
>  winsup/cygwin/exceptions.cc | 6 ++++++
>  winsup/cygwin/sigproc.cc    | 1 +
>  2 files changed, 7 insertions(+)
> 
> diff --git a/winsup/cygwin/exceptions.cc b/winsup/cygwin/exceptions.cc
> index 0f8c21939..7fc644af1 100644
> --- a/winsup/cygwin/exceptions.cc
> +++ b/winsup/cygwin/exceptions.cc
> @@ -978,6 +978,9 @@ sigpacket::setup_handler (void *handler, struct 
> sigaction& siga, _cygtls *tls)
>    CONTEXT cx;
>    bool interrupted = false;
>  
> +  for (int i = 0; i < 100 && tls->current_sig; i++)
> +    yield ();
> +

Is that a piece of stray code left from testing, or is that actually
part of the patch?  The commit message doesn't explain it...


Thanks,
Corinna

Reply via email to