107 lines
2.2 KiB
Go
107 lines
2.2 KiB
Go
// Copyright 2009 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.
|
|
|
|
package runtime
|
|
|
|
import (
|
|
"unsafe"
|
|
)
|
|
|
|
// For C code to call:
|
|
//go:linkname minit
|
|
|
|
func goenvs() {
|
|
goenvs_unix()
|
|
}
|
|
|
|
// Called to initialize a new m (including the bootstrap m).
|
|
// Called on the parent thread (main thread in case of bootstrap), can allocate memory.
|
|
func mpreinit(mp *m) {
|
|
mp.gsignal = malg(true, true, &mp.gsignalstack, &mp.gsignalstacksize)
|
|
mp.gsignal.m = mp
|
|
}
|
|
|
|
// minit is called to initialize a new m (including the bootstrap m).
|
|
// Called on the new thread, cannot allocate memory.
|
|
func minit() {
|
|
minitSignals()
|
|
|
|
getg().m.procid = getProcID()
|
|
}
|
|
|
|
// Called from dropm to undo the effect of an minit.
|
|
//go:nosplit
|
|
//go:nowritebarrierrec
|
|
func unminit() {
|
|
unminitSignals()
|
|
}
|
|
|
|
// Called from exitm, but not from drop, to undo the effect of thread-owned
|
|
// resources in minit, semacreate, or elsewhere. Do not take locks after calling this.
|
|
func mdestroy(mp *m) {
|
|
}
|
|
|
|
var urandom_dev = []byte("/dev/urandom\x00")
|
|
|
|
func getRandomData(r []byte) {
|
|
if startupRandomData != nil {
|
|
n := copy(r, startupRandomData)
|
|
extendRandom(r, n)
|
|
return
|
|
}
|
|
fd := open(&urandom_dev[0], 0 /* O_RDONLY */, 0)
|
|
n := read(fd, unsafe.Pointer(&r[0]), int32(len(r)))
|
|
closefd(fd)
|
|
extendRandom(r, int(n))
|
|
}
|
|
|
|
//go:noescape
|
|
//extern-sysinfo pipe
|
|
func libcPipe(*[2]int32) int32
|
|
|
|
func pipe() (r, w int32, e int32) {
|
|
var p [2]int32
|
|
res := libcPipe(&p)
|
|
if res < 0 {
|
|
e = int32(errno())
|
|
}
|
|
return p[0], p[1], e
|
|
}
|
|
|
|
//go:noescape
|
|
//extern-sysinfo pipe2
|
|
func libcPipe2(*[2]int32, int32) int32
|
|
|
|
func pipe2(flags int32) (r, w int32, e int32) {
|
|
var p [2]int32
|
|
res := libcPipe2(&p, flags)
|
|
if res < 0 {
|
|
e = int32(errno())
|
|
}
|
|
return p[0], p[1], e
|
|
}
|
|
|
|
//extern __go_fcntl_uintptr
|
|
func fcntlUintptr(fd, cmd, arg uintptr) (uintptr, uintptr)
|
|
|
|
//go:nosplit
|
|
func closeonexec(fd int32) {
|
|
fcntlUintptr(uintptr(fd), _F_SETFD, _FD_CLOEXEC)
|
|
}
|
|
|
|
//go:nosplit
|
|
func setNonblock(fd int32) {
|
|
flags, errno := fcntlUintptr(uintptr(fd), _F_GETFL, 0)
|
|
if errno == 0 {
|
|
fcntlUintptr(uintptr(fd), _F_SETFL, flags|_O_NONBLOCK)
|
|
}
|
|
}
|
|
|
|
// For gccgo this is in the C code.
|
|
func osyield()
|
|
|
|
//go:nosplit
|
|
func osyield_no_g() {
|
|
osyield()
|
|
}
|