mirror of
https://github.com/golang/go.git
synced 2025-05-05 15:43:04 +00:00
The syscall.AllThreadsSyscall() fixup mechanism needs to cooperate with signal handling to ensure a notetsleepg() thread can wake up to run the mDoFixup() function. Fixes #43149 Change-Id: I6651b25bc44a4de47d3fb71d0293d51aef8b79c7 Reviewed-on: https://go-review.googlesource.com/c/go/+/277434 Run-TryBot: Ian Lance Taylor <iant@golang.org> TryBot-Result: Go Bot <gobot@golang.org> Trust: Austin Clements <austin@google.com> Reviewed-by: Ian Lance Taylor <iant@golang.org>
43 lines
1.1 KiB
Go
43 lines
1.1 KiB
Go
// Copyright 2020 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.
|
|
|
|
// +build linux
|
|
|
|
package signal
|
|
|
|
import (
|
|
"os"
|
|
"syscall"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
const prSetKeepCaps = 8
|
|
|
|
// This test validates that syscall.AllThreadsSyscall() can reliably
|
|
// reach all 'm' (threads) of the nocgo runtime even when one thread
|
|
// is blocked waiting to receive signals from the kernel. This monitors
|
|
// for a regression vs. the fix for #43149.
|
|
func TestAllThreadsSyscallSignals(t *testing.T) {
|
|
if _, _, err := syscall.AllThreadsSyscall(syscall.SYS_PRCTL, prSetKeepCaps, 0, 0); err == syscall.ENOTSUP {
|
|
t.Skip("AllThreadsSyscall disabled with cgo")
|
|
}
|
|
|
|
sig := make(chan os.Signal, 1)
|
|
Notify(sig, os.Interrupt)
|
|
|
|
for i := 0; i <= 100; i++ {
|
|
if _, _, errno := syscall.AllThreadsSyscall(syscall.SYS_PRCTL, prSetKeepCaps, uintptr(i&1), 0); errno != 0 {
|
|
t.Fatalf("[%d] failed to set KEEP_CAPS=%d: %v", i, i&1, errno)
|
|
}
|
|
}
|
|
|
|
select {
|
|
case <-time.After(10 * time.Millisecond):
|
|
case <-sig:
|
|
t.Fatal("unexpected signal")
|
|
}
|
|
Stop(sig)
|
|
}
|