summaryrefslogtreecommitdiff
path: root/libgcc
diff options
context:
space:
mode:
authorIan Lance Taylor <iant@golang.org>2020-12-08 10:17:16 -0800
committerIan Lance Taylor <iant@golang.org>2020-12-08 10:17:48 -0800
commitf41dd93ade24f22f8cd1863129ab20c821000134 (patch)
tree0ef3090bf53a06032bd7848367ffbed864dd0dc4 /libgcc
parentc0ed52d3e0044630b57a2145be78de199539d995 (diff)
downloadgcc-f41dd93ade24f22f8cd1863129ab20c821000134.tar.gz
libgcc: block signals when releasing split-stack memory
* generic-morestack-thread.c (free_segments): Block signals during thread exit.
Diffstat (limited to 'libgcc')
-rw-r--r--libgcc/generic-morestack-thread.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/libgcc/generic-morestack-thread.c b/libgcc/generic-morestack-thread.c
index 83a65501272..fd391bb2e1f 100644
--- a/libgcc/generic-morestack-thread.c
+++ b/libgcc/generic-morestack-thread.c
@@ -38,6 +38,7 @@ see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
#ifndef inhibit_libc
#include <errno.h>
+#include <signal.h>
#include <pthread.h>
#include "generic-morestack.h"
@@ -54,6 +55,9 @@ extern int pthread_key_create (pthread_key_t *, void (*) (void *))
extern int pthread_setspecific (pthread_key_t, const void *)
__attribute__ ((weak));
+extern int pthread_sigmask (int, const sigset_t *, sigset_t *)
+ __attribute__ ((weak));
+
/* The key for the list of stack segments to free when the thread
exits. This is created by pthread_key_create. */
@@ -70,6 +74,16 @@ static pthread_once_t create_key_once = PTHREAD_ONCE_INIT;
static void
free_segments (void* arg)
{
+ /* We must block signals in case the signal handler tries to split
+ the stack. We leave them blocked while the thread exits. */
+ if (pthread_sigmask)
+ {
+ sigset_t mask;
+
+ sigfillset (&mask);
+ pthread_sigmask (SIG_BLOCK, &mask, NULL);
+ }
+
__morestack_release_segments ((struct stack_segment **) arg, 1);
}