t_cpuctl.sh revision 1.6 1 1.6 mrg # $NetBSD: t_cpuctl.sh,v 1.6 2021/04/12 01:18:13 mrg Exp $
2 1.1 jruoho #
3 1.1 jruoho # Copyright (c) 2020 The NetBSD Foundation, Inc.
4 1.1 jruoho # All rights reserved.
5 1.1 jruoho #
6 1.1 jruoho # This code is derived from software contributed to The NetBSD Foundation
7 1.1 jruoho # by Jukka Ruohonen.
8 1.1 jruoho #
9 1.1 jruoho # Redistribution and use in source and binary forms, with or without
10 1.1 jruoho # modification, are permitted provided that the following conditions
11 1.1 jruoho # are met:
12 1.1 jruoho # 1. Redistributions of source code must retain the above copyright
13 1.1 jruoho # notice, this list of conditions and the following disclaimer.
14 1.1 jruoho # 2. Redistributions in binary form must reproduce the above copyright
15 1.1 jruoho # notice, this list of conditions and the following disclaimer in the
16 1.1 jruoho # documentation and/or other materials provided with the distribution.
17 1.1 jruoho #
18 1.1 jruoho # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
19 1.1 jruoho # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20 1.1 jruoho # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 1.1 jruoho # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
22 1.1 jruoho # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 1.1 jruoho # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 1.1 jruoho # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 1.1 jruoho # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 1.1 jruoho # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 1.1 jruoho # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 1.1 jruoho # POSSIBILITY OF SUCH DAMAGE.
29 1.1 jruoho #
30 1.1 jruoho tmp="/tmp/cpuctl.txt"
31 1.1 jruoho
32 1.1 jruoho setcpu() {
33 1.1 jruoho
34 1.1 jruoho ncpu=$(sysctl -n hw.ncpu)
35 1.1 jruoho
36 1.1 jruoho if [ $ncpu -eq 1 ]; then
37 1.1 jruoho atf_pass
38 1.1 jruoho fi
39 1.1 jruoho
40 1.1 jruoho while [ $ncpu -gt 1 ]; do
41 1.1 jruoho
42 1.5 martin cpuid=$(( $ncpu - 1 ))
43 1.1 jruoho cpuctl $1 $cpuid >/dev/null 2>&1
44 1.1 jruoho
45 1.1 jruoho if [ ! $? -eq 0 ]; then
46 1.1 jruoho $2 $3
47 1.1 jruoho fi
48 1.1 jruoho
49 1.5 martin ncpu=$(( $ncpu - 1 ))
50 1.1 jruoho done
51 1.4 jruoho
52 1.4 jruoho # Additional check that interrupts cannot be
53 1.4 jruoho # disabled for the primary CPU (PR kern/45117).
54 1.4 jruoho #
55 1.4 jruoho cpuctl nointr 0 >/dev/null 2>&1
56 1.4 jruoho
57 1.4 jruoho if [ $? -eq 0 ]; then
58 1.4 jruoho $2 $3
59 1.4 jruoho fi
60 1.1 jruoho }
61 1.1 jruoho
62 1.1 jruoho clean() {
63 1.1 jruoho
64 1.1 jruoho i=0
65 1.1 jruoho
66 1.1 jruoho while read line; do
67 1.1 jruoho
68 1.5 martin i=$(( $i + 1 ))
69 1.1 jruoho
70 1.1 jruoho if [ $i -lt 3 ]; then
71 1.1 jruoho continue
72 1.1 jruoho fi
73 1.1 jruoho
74 1.1 jruoho cpuid=$(echo $line | awk '{print $1}')
75 1.1 jruoho online=$(echo $line | awk '{print $3}')
76 1.1 jruoho intr=$(echo $line | awk '{print $4}')
77 1.1 jruoho
78 1.1 jruoho cpuctl $online $cpuid
79 1.1 jruoho cpuctl $intr $cpuid
80 1.1 jruoho
81 1.1 jruoho done < $tmp
82 1.1 jruoho
83 1.1 jruoho rm $tmp
84 1.1 jruoho }
85 1.1 jruoho
86 1.1 jruoho # ncpu.
87 1.1 jruoho #
88 1.1 jruoho atf_test_case ncpu
89 1.1 jruoho ncpu_head() {
90 1.1 jruoho atf_require_prog cpuctl
91 1.1 jruoho atf_set "descr" "Test that cpuctl(8) returns the " \
92 1.1 jruoho "same number of CPUs as sysctl(8)"
93 1.1 jruoho }
94 1.1 jruoho
95 1.1 jruoho ncpu_body() {
96 1.1 jruoho
97 1.1 jruoho lst=$(cpuctl list | wc -l)
98 1.5 martin ncpu=$(( $lst - 2 ))
99 1.1 jruoho
100 1.1 jruoho if [ $ncpu -eq 1 ]; then
101 1.1 jruoho atf_pass
102 1.1 jruoho fi
103 1.1 jruoho
104 1.1 jruoho if [ $(sysctl -n hw.ncpu) -eq $ncpu ]; then
105 1.1 jruoho atf_pass
106 1.1 jruoho fi
107 1.1 jruoho
108 1.1 jruoho atf_fail "Different number of CPUs"
109 1.1 jruoho }
110 1.1 jruoho
111 1.1 jruoho # err
112 1.1 jruoho #
113 1.1 jruoho atf_test_case err cleanup
114 1.1 jruoho err_head() {
115 1.1 jruoho atf_require_prog cpuctl
116 1.1 jruoho atf_set "require.user" "root"
117 1.1 jruoho atf_set "descr" "Test invalid parameters to cpuctl(8)"
118 1.1 jruoho }
119 1.1 jruoho
120 1.1 jruoho err_body() {
121 1.1 jruoho
122 1.1 jruoho cpuctl list > $tmp
123 1.1 jruoho ncpu=$(sysctl -n hw.ncpu)
124 1.1 jruoho
125 1.1 jruoho atf_check -s exit:1 -e ignore \
126 1.1 jruoho -o empty -x cpuctl identify -1
127 1.1 jruoho
128 1.1 jruoho atf_check -s exit:1 -e ignore \
129 1.1 jruoho -o empty -x cpuctl offline -1
130 1.1 jruoho
131 1.1 jruoho atf_check -s exit:1 -e ignore \
132 1.1 jruoho -o empty -x cpuctl nointr -1
133 1.1 jruoho
134 1.1 jruoho atf_check -s exit:1 -e ignore \
135 1.5 martin -o empty -x cpuctl identify $(( $ncpu + 1 ))
136 1.1 jruoho
137 1.1 jruoho atf_check -s exit:1 -e ignore \
138 1.5 martin -o empty -x cpuctl offline $(( $ncpu + 1 ))
139 1.1 jruoho
140 1.1 jruoho atf_check -s exit:1 -e ignore \
141 1.5 martin -o empty -x cpuctl nointr $(( $ncpu + 1 ))
142 1.1 jruoho }
143 1.1 jruoho
144 1.1 jruoho err_cleanup() {
145 1.1 jruoho clean
146 1.1 jruoho }
147 1.1 jruoho
148 1.1 jruoho # identify
149 1.1 jruoho #
150 1.1 jruoho atf_test_case identify
151 1.1 jruoho identify_head() {
152 1.1 jruoho atf_require_prog cpuctl
153 1.1 jruoho atf_set "descr" "Test that cpuctl(8) identifies at least " \
154 1.1 jruoho "something without segfaulting (PR bin/54220)"
155 1.1 jruoho }
156 1.1 jruoho
157 1.1 jruoho identify_body() {
158 1.1 jruoho
159 1.1 jruoho ncpu=$(sysctl -n hw.ncpu)
160 1.1 jruoho
161 1.1 jruoho while [ $ncpu -gt 0 ]; do
162 1.5 martin cpuid=$(( $ncpu - 1 ))
163 1.1 jruoho atf_check -s exit:0 -o not-empty -x cpuctl identify $cpuid
164 1.5 martin ncpu=$(( $ncpu - 1 ))
165 1.1 jruoho done
166 1.1 jruoho
167 1.1 jruoho atf_pass
168 1.1 jruoho }
169 1.1 jruoho
170 1.6 mrg #
171 1.6 mrg # check_cpuctl_ok - only run some tests if
172 1.6 mrg # is set ATF_USR_SBIN_CPUCTL_OFFLINE_ENABLE.
173 1.6 mrg check_cpuctl_ok() {
174 1.6 mrg if [ -z "$ATF_USR_SBIN_CPUCTL_OFFLINE_ENABLE" ]; then
175 1.6 mrg return 1
176 1.6 mrg fi
177 1.6 mrg return 0
178 1.6 mrg }
179 1.6 mrg
180 1.1 jruoho # offline
181 1.1 jruoho #
182 1.1 jruoho atf_test_case offline cleanup
183 1.1 jruoho offline_head() {
184 1.1 jruoho atf_require_prog cpuctl
185 1.1 jruoho atf_set "require.user" "root"
186 1.1 jruoho atf_set "descr" "Test setting CPUs offline"
187 1.1 jruoho }
188 1.1 jruoho
189 1.1 jruoho offline_body() {
190 1.1 jruoho
191 1.6 mrg if ! check_cpuctl_ok; then
192 1.6 mrg atf_skip \
193 1.6 mrg "test sometimes hangs or upsets machine"
194 1.6 mrg fi
195 1.6 mrg
196 1.1 jruoho cpuctl list > $tmp
197 1.1 jruoho setcpu "offline" atf_fail "error in setting a CPU offline"
198 1.1 jruoho
199 1.1 jruoho # Additional check that the boot processor cannot be
200 1.2 jruoho # set offline, as noted in the cpuctl(8) manual page.
201 1.1 jruoho #
202 1.1 jruoho cpuctl offline 0 >/dev/null 2>&1
203 1.1 jruoho
204 1.1 jruoho if [ $? -eq 0 ]; then
205 1.1 jruoho $2 $3
206 1.1 jruoho fi
207 1.1 jruoho }
208 1.1 jruoho
209 1.1 jruoho offline_cleanup() {
210 1.1 jruoho clean
211 1.1 jruoho }
212 1.1 jruoho
213 1.1 jruoho atf_test_case offline_perm
214 1.1 jruoho offline_perm_head() {
215 1.1 jruoho atf_require_prog cpuctl
216 1.1 jruoho atf_set "require.user" "unprivileged"
217 1.1 jruoho atf_set "descr" "Test setting CPUs offline as a user"
218 1.1 jruoho }
219 1.1 jruoho
220 1.1 jruoho offline_perm_body() {
221 1.1 jruoho setcpu "offline" atf_pass
222 1.1 jruoho }
223 1.1 jruoho
224 1.1 jruoho # nointr
225 1.1 jruoho #
226 1.1 jruoho atf_test_case nointr cleanup
227 1.1 jruoho nointr_head() {
228 1.1 jruoho atf_require_prog cpuctl
229 1.1 jruoho atf_set "require.user" "root"
230 1.1 jruoho atf_set "descr" "Test disabling interrupts for CPUs"
231 1.1 jruoho }
232 1.1 jruoho
233 1.1 jruoho nointr_body() {
234 1.6 mrg
235 1.6 mrg if ! check_cpuctl_ok; then
236 1.6 mrg atf_skip \
237 1.6 mrg "test sometimes hangs or upsets machine"
238 1.6 mrg fi
239 1.6 mrg
240 1.1 jruoho cpuctl list > $tmp
241 1.1 jruoho setcpu "nointr" atf_fail "error in disabling interrupts"
242 1.1 jruoho }
243 1.1 jruoho
244 1.1 jruoho nointr_cleanup() {
245 1.1 jruoho clean
246 1.1 jruoho }
247 1.1 jruoho
248 1.1 jruoho atf_test_case nointr_perm
249 1.1 jruoho nointr_perm_head() {
250 1.1 jruoho atf_require_prog cpuctl
251 1.1 jruoho atf_set "require.user" "unprivileged"
252 1.1 jruoho atf_set "descr" "Test disabling interrupts as a user"
253 1.1 jruoho }
254 1.1 jruoho
255 1.1 jruoho nointr_perm_body() {
256 1.1 jruoho setcpu "nointr" atf_pass
257 1.1 jruoho }
258 1.1 jruoho
259 1.1 jruoho atf_init_test_cases() {
260 1.1 jruoho atf_add_test_case ncpu
261 1.1 jruoho atf_add_test_case err
262 1.1 jruoho atf_add_test_case identify
263 1.1 jruoho atf_add_test_case offline
264 1.1 jruoho atf_add_test_case offline_perm
265 1.1 jruoho atf_add_test_case nointr
266 1.1 jruoho atf_add_test_case nointr_perm
267 1.1 jruoho }
268