2015-09-10 09:21:57 -06:00
|
|
|
// Copyright 2015 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
|
2016-04-05 22:38:00 -06:00
|
|
|
// +build mips64 mips64le
|
2015-09-10 09:21:57 -06:00
|
|
|
|
|
|
|
package runtime
|
|
|
|
|
|
|
|
var randomNumber uint32
|
|
|
|
|
2016-05-05 22:53:42 -06:00
|
|
|
func archauxv(tag, val uintptr) {
|
|
|
|
switch tag {
|
|
|
|
case _AT_RANDOM:
|
|
|
|
// sysargs filled in startupRandomData, but that
|
|
|
|
// pointer may not be word aligned, so we must treat
|
|
|
|
// it as a byte array.
|
|
|
|
randomNumber = uint32(startupRandomData[4]) | uint32(startupRandomData[5])<<8 |
|
|
|
|
uint32(startupRandomData[6])<<16 | uint32(startupRandomData[7])<<24
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-09-10 09:21:57 -06:00
|
|
|
//go:nosplit
|
|
|
|
func cputicks() int64 {
|
2016-06-28 10:22:46 -06:00
|
|
|
// Currently cputicks() is used in blocking profiler and to seed fastrand().
|
2015-09-10 09:21:57 -06:00
|
|
|
// nanotime() is a poor approximation of CPU ticks that is enough for the profiler.
|
2016-06-28 10:22:46 -06:00
|
|
|
// randomNumber provides better seeding of fastrand.
|
2015-09-10 09:21:57 -06:00
|
|
|
return nanotime() + int64(randomNumber)
|
|
|
|
}
|
2016-04-05 22:38:00 -06:00
|
|
|
|
|
|
|
const (
|
|
|
|
_SS_DISABLE = 2
|
2016-10-18 15:51:01 -06:00
|
|
|
_NSIG = 129
|
2016-04-05 22:38:00 -06:00
|
|
|
_SI_USER = 0
|
|
|
|
_SIG_BLOCK = 1
|
|
|
|
_SIG_UNBLOCK = 2
|
|
|
|
_SIG_SETMASK = 3
|
|
|
|
_RLIMIT_AS = 6
|
|
|
|
)
|
|
|
|
|
|
|
|
type sigset [2]uint64
|
|
|
|
|
|
|
|
type rlimit struct {
|
|
|
|
rlim_cur uintptr
|
|
|
|
rlim_max uintptr
|
|
|
|
}
|
|
|
|
|
|
|
|
var sigset_all = sigset{^uint64(0), ^uint64(0)}
|
|
|
|
|
2016-09-27 14:42:28 -06:00
|
|
|
//go:nosplit
|
|
|
|
//go:nowritebarrierrec
|
2016-04-05 22:38:00 -06:00
|
|
|
func sigaddset(mask *sigset, i int) {
|
|
|
|
(*mask)[(i-1)/64] |= 1 << ((uint32(i) - 1) & 63)
|
|
|
|
}
|
|
|
|
|
|
|
|
func sigdelset(mask *sigset, i int) {
|
|
|
|
(*mask)[(i-1)/64] &^= 1 << ((uint32(i) - 1) & 63)
|
|
|
|
}
|
|
|
|
|
|
|
|
func sigfillset(mask *[2]uint64) {
|
|
|
|
(*mask)[0], (*mask)[1] = ^uint64(0), ^uint64(0)
|
|
|
|
}
|