From fab94894d5c5b25d24010f823515fb53822d6623 Mon Sep 17 00:00:00 2001 From: Samuel Thibault Date: Sun, 7 Jun 2020 01:55:54 +0200 Subject: [PATCH] hurd: Fix hang in _hurd_raise_signal from pthread_kill When ss is not NULL, it is assumed to be locked. * hurd/hurd-raise.c (_hurd_raise_signal): Unlock before returning an error if ss is not NULL. --- hurd/hurd-raise.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/hurd/hurd-raise.c b/hurd/hurd-raise.c index af464377b6..865e498bf9 100644 --- a/hurd/hurd-raise.c +++ b/hurd/hurd-raise.c @@ -29,7 +29,11 @@ _hurd_raise_signal (struct hurd_sigstate *ss, int signo, const struct hurd_signal_detail *detail) { if (signo <= 0 || signo >= NSIG) - return EINVAL; + { + if (ss) + __spin_unlock (&ss->lock); + return EINVAL; + } if (ss == NULL) {