diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2020-06-27 02:34:18 +0200 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2020-06-27 02:34:18 +0200 |
commit | 726117e01b59b129d471304fec4bf78fa280ff9e (patch) | |
tree | 7863a09ccc234c98c259d767ead0af31f81d8ae3 | |
parent | b9ca3f3efb4659cadf4b0b81308ce9d45de61e0b (diff) | |
download | glibc-726117e01b59b129d471304fec4bf78fa280ff9e.tar glibc-726117e01b59b129d471304fec4bf78fa280ff9e.tar.gz glibc-726117e01b59b129d471304fec4bf78fa280ff9e.tar.bz2 glibc-726117e01b59b129d471304fec4bf78fa280ff9e.zip |
htl: avoid cancelling threads inside critical sections
Like hurd_thread_cancel does.
* sysdeps/mach/hurd/htl/pt-docancel.c: Include <hurd/signal.h>
(__pthread_do_cancel): Lock target thread's critical_section_lock and ss
lock around thread mangling.
-rw-r--r-- | sysdeps/mach/hurd/htl/pt-docancel.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/sysdeps/mach/hurd/htl/pt-docancel.c b/sysdeps/mach/hurd/htl/pt-docancel.c index 93961060a2..52010b6edf 100644 --- a/sysdeps/mach/hurd/htl/pt-docancel.c +++ b/sysdeps/mach/hurd/htl/pt-docancel.c @@ -17,6 +17,7 @@ <https://www.gnu.org/licenses/>. */ #include <pthread.h> +#include <hurd/signal.h> #include <pt-internal.h> #include <pthreadP.h> @@ -47,10 +48,16 @@ __pthread_do_cancel (struct __pthread *p) else { error_t err; + struct hurd_sigstate *ss = _hurd_thread_sigstate (p->kernel_thread); + + __spin_lock (&ss->critical_section_lock); + __spin_lock (&ss->lock); err = __thread_suspend (p->kernel_thread); assert_perror (err); + __spin_unlock (&ss->lock); + err = __thread_abort (p->kernel_thread); assert_perror (err); @@ -60,6 +67,8 @@ __pthread_do_cancel (struct __pthread *p) err = __thread_resume (p->kernel_thread); assert_perror (err); + + _hurd_critical_section_unlock (ss); } return 0; |