Commit 73d20f81 authored by Cherry Zhang's avatar Cherry Zhang

runtime: always use Go signal stack in non-cgo program

When initializing an M, we set up its signal stack to the gsignal
stack if an alternate signal stack is not already set. On Android,
an alternate signal stack is always set, even cgo is not used.
This breaks the logic of saving/fetching G on the signal stack
during VDSO, which assumes the signal stack is allocated by Go if
cgo is not used (if cgo is used, we use TLS for saving G).

When cgo is not used, we can always use the Go signal stack, even
if an alternate signal stack is already set. Since cgo is not
used, no one other than the Go runtime will care.

Fixes #35554.

Change-Id: Ia9d84cd55cb35097f3df46f37996589c86f10e0f
Reviewed-on: https://go-review.googlesource.com/c/go/+/207445
Run-TryBot: Cherry Zhang <cherryyz@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent f9dd99ca
...@@ -1016,13 +1016,15 @@ func minitSignals() { ...@@ -1016,13 +1016,15 @@ func minitSignals() {
// stack to the gsignal stack. If the alternate signal stack is set // stack to the gsignal stack. If the alternate signal stack is set
// for the thread (the case when a non-Go thread sets the alternate // for the thread (the case when a non-Go thread sets the alternate
// signal stack and then calls a Go function) then set the gsignal // signal stack and then calls a Go function) then set the gsignal
// stack to the alternate signal stack. Record which choice was made // stack to the alternate signal stack. We also set the alternate
// in newSigstack, so that it can be undone in unminit. // signal stack to the gsignal stack if cgo is not used (regardless
// of whether it is already set). Record which choice was made in
// newSigstack, so that it can be undone in unminit.
func minitSignalStack() { func minitSignalStack() {
_g_ := getg() _g_ := getg()
var st stackt var st stackt
sigaltstack(nil, &st) sigaltstack(nil, &st)
if st.ss_flags&_SS_DISABLE != 0 { if st.ss_flags&_SS_DISABLE != 0 || !iscgo {
signalstack(&_g_.m.gsignal.stack) signalstack(&_g_.m.gsignal.stack)
_g_.m.newSigstack = true _g_.m.newSigstack = true
} else { } else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment