]> Cypherpunks repositories - gostls13.git/commitdiff
runtime/cgo: linux signal masking
authorMikio Hara <mikioh.mikioh@gmail.com>
Wed, 14 Mar 2012 04:07:25 +0000 (13:07 +0900)
committerMikio Hara <mikioh.mikioh@gmail.com>
Wed, 14 Mar 2012 04:07:25 +0000 (13:07 +0900)
Fixes #3314.
Fixes #3101 (again).

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/5820047

src/pkg/runtime/cgo/gcc_linux_386.c
src/pkg/runtime/cgo/gcc_linux_amd64.c

index 8401a75caa82a090090676f31ebd3a2d8d02e672..7d84acc11efdc30e90f487c932ae01add78e2efb 100644 (file)
@@ -4,6 +4,7 @@
 
 #include <pthread.h>
 #include <string.h>
+#include <signal.h>
 #include "libcgo.h"
 
 static void *threadentry(void*);
@@ -26,10 +27,14 @@ void
 libcgo_sys_thread_start(ThreadStart *ts)
 {
        pthread_attr_t attr;
+       sigset_t ign, oset;
        pthread_t p;
        size_t size;
        int err;
 
+       sigfillset(&ign);
+       sigprocmask(SIG_SETMASK, &ign, &oset);
+
        // Not sure why the memset is necessary here,
        // but without it, we get a bogus stack size
        // out of pthread_attr_getstacksize.  C'est la Linux.
@@ -39,6 +44,9 @@ libcgo_sys_thread_start(ThreadStart *ts)
        pthread_attr_getstacksize(&attr, &size);
        ts->g->stackguard = size;
        err = pthread_create(&p, &attr, threadentry, ts);
+
+       sigprocmask(SIG_SETMASK, &oset, nil);
+
        if (err != 0) {
                fprintf(stderr, "runtime/cgo: pthread_create failed: %s\n", strerror(err));
                abort();
index 6ce3333a858fc7adb2cac3c2d270a6fb9cf2e8e1..28cbf78c525b7afe551a1dce264973360ff03568 100644 (file)
@@ -4,6 +4,7 @@
 
 #include <pthread.h>
 #include <string.h> // strerror
+#include <signal.h>
 #include "libcgo.h"
 
 static void* threadentry(void*);
@@ -26,14 +27,21 @@ void
 libcgo_sys_thread_start(ThreadStart *ts)
 {
        pthread_attr_t attr;
+       sigset_t ign, oset;
        pthread_t p;
        size_t size;
        int err;
 
+       sigfillset(&ign);
+       sigprocmask(SIG_SETMASK, &ign, &oset);
+
        pthread_attr_init(&attr);
        pthread_attr_getstacksize(&attr, &size);
        ts->g->stackguard = size;
        err = pthread_create(&p, &attr, threadentry, ts);
+
+       sigprocmask(SIG_SETMASK, &oset, nil);
+
        if (err != 0) {
                fprintf(stderr, "runtime/cgo: pthread_create failed: %s\n", strerror(err));
                abort();