mirror of
https://github.com/golang/go
synced 2024-11-23 12:00:14 -07:00
c4770b991b
NPTL uses SIGRTMIN (signal 32) to effect thread cancellation. Go's runtime replaces NPTL's signal handler with its own, and ends up aborting if a C library that ends up calling pthread_cancel is used. This patch prevents runtime from replacing NPTL's handler. Fixes #6997. R=golang-codereviews, iant, dvyukov CC=golang-codereviews https://golang.org/cl/47540043
41 lines
859 B
Go
41 lines
859 B
Go
// Copyright 2014 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// Test that pthread_cancel works as expected
|
|
// (NPTL uses SIGRTMIN to implement thread cancellation)
|
|
// See http://golang.org/issue/6997
|
|
package cgotest
|
|
|
|
/*
|
|
#cgo CFLAGS: -pthread
|
|
#cgo LDFLAGS: -pthread
|
|
extern int StartThread();
|
|
extern int CancelThread();
|
|
*/
|
|
import "C"
|
|
|
|
import "testing"
|
|
import "time"
|
|
|
|
func test6997(t *testing.T) {
|
|
r := C.StartThread()
|
|
if r != 0 {
|
|
t.Error("pthread_create failed")
|
|
}
|
|
c := make(chan C.int)
|
|
go func() {
|
|
time.Sleep(500 * time.Millisecond)
|
|
c <- C.CancelThread()
|
|
}()
|
|
|
|
select {
|
|
case r = <-c:
|
|
if r == 0 {
|
|
t.Error("pthread finished but wasn't cancelled??")
|
|
}
|
|
case <-time.After(5 * time.Second):
|
|
t.Error("hung in pthread_cancel/pthread_join")
|
|
}
|
|
}
|