mirror of
https://github.com/golang/go
synced 2024-11-18 09:04:49 -07:00
runtime, os/signal: use //go:linkname instead of assembly stubs to get access to runtime functions
os/signal depends on a few unexported runtime functions. This removes the assembly stubs it used to get access to these in favour of using //go:linkname in runtime to make the functions accessible to os/signal. This is motivated by ppc64le shared libraries, where you cannot BR to a symbol defined in a shared library (only BL), but it seems like an improvment anyway. Change-Id: I09361203ce38070bd3f132f6dc5ac212f2dc6f58 Reviewed-on: https://go-review.googlesource.com/15871 Run-TryBot: Michael Hudson-Doyle <michael.hudson@canonical.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Minux Ma <minux@golang.org> Reviewed-by: Dave Cheney <dave@cheney.net>
This commit is contained in:
parent
4c2465d47d
commit
0b8d583320
@ -2,31 +2,7 @@
|
||||
// Use of this source code is governed by a BSD-style
|
||||
// license that can be found in the LICENSE file.
|
||||
|
||||
// Assembly to get into package runtime without using exported symbols.
|
||||
|
||||
// +build amd64 amd64p32 arm arm64 386 ppc64 ppc64le
|
||||
|
||||
#include "textflag.h"
|
||||
|
||||
#ifdef GOARCH_arm
|
||||
#define JMP B
|
||||
#endif
|
||||
#ifdef GOARCH_ppc64
|
||||
#define JMP BR
|
||||
#endif
|
||||
#ifdef GOARCH_ppc64le
|
||||
#define JMP BR
|
||||
#endif
|
||||
|
||||
TEXT ·signal_disable(SB),NOSPLIT,$0
|
||||
JMP runtime·signal_disable(SB)
|
||||
|
||||
TEXT ·signal_enable(SB),NOSPLIT,$0
|
||||
JMP runtime·signal_enable(SB)
|
||||
|
||||
TEXT ·signal_ignore(SB),NOSPLIT,$0
|
||||
JMP runtime·signal_ignore(SB)
|
||||
|
||||
TEXT ·signal_recv(SB),NOSPLIT,$0
|
||||
JMP runtime·signal_recv(SB)
|
||||
|
||||
// The runtime package uses //go:linkname to push a few functions into this
|
||||
// package but we still need a .s file so the Go tool does not pass -complete
|
||||
// to the go tool compile so the latter does not complain about Go functions
|
||||
// with no bodies.
|
||||
|
@ -11,7 +11,7 @@ import (
|
||||
"syscall"
|
||||
)
|
||||
|
||||
// In assembly.
|
||||
// Defined by the runtime package.
|
||||
func signal_disable(uint32)
|
||||
func signal_enable(uint32)
|
||||
func signal_ignore(uint32)
|
||||
|
@ -90,6 +90,7 @@ Send:
|
||||
|
||||
// Called to receive the next queued signal.
|
||||
// Must only be called from a single goroutine at a time.
|
||||
//go:linkname signal_recv os/signal.signal_recv
|
||||
func signal_recv() uint32 {
|
||||
for {
|
||||
// Serve any signals from local copy.
|
||||
@ -127,6 +128,7 @@ func signal_recv() uint32 {
|
||||
}
|
||||
|
||||
// Must only be called from a single goroutine at a time.
|
||||
//go:linkname signal_enable os/signal.signal_enable
|
||||
func signal_enable(s uint32) {
|
||||
if !sig.inuse {
|
||||
// The first call to signal_enable is for us
|
||||
@ -145,6 +147,7 @@ func signal_enable(s uint32) {
|
||||
}
|
||||
|
||||
// Must only be called from a single goroutine at a time.
|
||||
//go:linkname signal_disable os/signal.signal_disable
|
||||
func signal_disable(s uint32) {
|
||||
if s >= uint32(len(sig.wanted)*32) {
|
||||
return
|
||||
@ -154,6 +157,7 @@ func signal_disable(s uint32) {
|
||||
}
|
||||
|
||||
// Must only be called from a single goroutine at a time.
|
||||
//go:linkname signal_ignore os/signal.signal_ignore
|
||||
func signal_ignore(s uint32) {
|
||||
if s >= uint32(len(sig.wanted)*32) {
|
||||
return
|
||||
|
@ -6,6 +6,8 @@
|
||||
|
||||
package runtime
|
||||
|
||||
import _ "unsafe"
|
||||
|
||||
const qsize = 64
|
||||
|
||||
var sig struct {
|
||||
@ -92,6 +94,7 @@ func sendNote(s *byte) bool {
|
||||
|
||||
// Called to receive the next queued signal.
|
||||
// Must only be called from a single goroutine at a time.
|
||||
//go:linkname signal_recv os/signal.signal_recv
|
||||
func signal_recv() string {
|
||||
for {
|
||||
note := sig.q.pop()
|
||||
@ -108,6 +111,7 @@ func signal_recv() string {
|
||||
}
|
||||
|
||||
// Must only be called from a single goroutine at a time.
|
||||
//go:linkname signal_enable os/signal.signal_enable
|
||||
func signal_enable(s uint32) {
|
||||
if !sig.inuse {
|
||||
// The first call to signal_enable is for us
|
||||
@ -120,9 +124,11 @@ func signal_enable(s uint32) {
|
||||
}
|
||||
|
||||
// Must only be called from a single goroutine at a time.
|
||||
//go:linkname signal_disable os/signal.signal_disable
|
||||
func signal_disable(s uint32) {
|
||||
}
|
||||
|
||||
// Must only be called from a single goroutine at a time.
|
||||
//go:linkname signal_ignore os/signal.signal_ignore
|
||||
func signal_ignore(s uint32) {
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user