liuxiaolong
2022-06-28 37714b1093c04061e636e5b1d27179652e671c0a
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
// Copyright 2018 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.
 
// CPU affinity functions
 
package unix
 
import (
    "math/bits"
    "unsafe"
)
 
const cpuSetSize = _CPU_SETSIZE / _NCPUBITS
 
// CPUSet represents a CPU affinity mask.
type CPUSet [cpuSetSize]cpuMask
 
func schedAffinity(trap uintptr, pid int, set *CPUSet) error {
    _, _, e := RawSyscall(trap, uintptr(pid), uintptr(unsafe.Sizeof(*set)), uintptr(unsafe.Pointer(set)))
    if e != 0 {
        return errnoErr(e)
    }
    return nil
}
 
// SchedGetaffinity gets the CPU affinity mask of the thread specified by pid.
// If pid is 0 the calling thread is used.
func SchedGetaffinity(pid int, set *CPUSet) error {
    return schedAffinity(SYS_SCHED_GETAFFINITY, pid, set)
}
 
// SchedSetaffinity sets the CPU affinity mask of the thread specified by pid.
// If pid is 0 the calling thread is used.
func SchedSetaffinity(pid int, set *CPUSet) error {
    return schedAffinity(SYS_SCHED_SETAFFINITY, pid, set)
}
 
// Zero clears the set s, so that it contains no CPUs.
func (s *CPUSet) Zero() {
    for i := range s {
        s[i] = 0
    }
}
 
func cpuBitsIndex(cpu int) int {
    return cpu / _NCPUBITS
}
 
func cpuBitsMask(cpu int) cpuMask {
    return cpuMask(1 << (uint(cpu) % _NCPUBITS))
}
 
// Set adds cpu to the set s.
func (s *CPUSet) Set(cpu int) {
    i := cpuBitsIndex(cpu)
    if i < len(s) {
        s[i] |= cpuBitsMask(cpu)
    }
}
 
// Clear removes cpu from the set s.
func (s *CPUSet) Clear(cpu int) {
    i := cpuBitsIndex(cpu)
    if i < len(s) {
        s[i] &^= cpuBitsMask(cpu)
    }
}
 
// IsSet reports whether cpu is in the set s.
func (s *CPUSet) IsSet(cpu int) bool {
    i := cpuBitsIndex(cpu)
    if i < len(s) {
        return s[i]&cpuBitsMask(cpu) != 0
    }
    return false
}
 
// Count returns the number of CPUs in the set s.
func (s *CPUSet) Count() int {
    c := 0
    for _, b := range s {
        c += bits.OnesCount64(uint64(b))
    }
    return c
}