lin
2025-06-05 ed3dd9d3e7519a82bb871d5eedb24a2fa0c91f47
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
// Copyright 2016 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
// +build mips mipsle
 
package runtime
 
var randomNumber uint32
 
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
   }
}
 
//go:nosplit
func cputicks() int64 {
   // Currently cputicks() is used in blocking profiler and to seed fastrand().
   // nanotime() is a poor approximation of CPU ticks that is enough for the profiler.
   // randomNumber provides better seeding of fastrand1.
   return nanotime() + int64(randomNumber)
}
 
const (
   _SS_DISABLE  = 2
   _NSIG        = 128 + 1
   _SI_USER     = 0
   _SIG_BLOCK   = 1
   _SIG_UNBLOCK = 2
   _SIG_SETMASK = 3
)
 
type sigset [4]uint32
 
var sigset_all = sigset{^uint32(0), ^uint32(0), ^uint32(0), ^uint32(0)}
 
//go:nosplit
//go:nowritebarrierrec
func sigaddset(mask *sigset, i int) {
   (*mask)[(i-1)/32] |= 1 << ((uint32(i) - 1) & 31)
}
 
func sigdelset(mask *sigset, i int) {
   (*mask)[(i-1)/32] &^= 1 << ((uint32(i) - 1) & 31)
}
 
func sigfillset(mask *[4]uint32) {
   (*mask)[0], (*mask)[1], (*mask)[2], (*mask)[3] = ^uint32(0), ^uint32(0), ^uint32(0), ^uint32(0)
}