2 # SPDX-License-Identifier: GPL-2.0
5 # Kselftest framework requirement - SKIP code is 4.
12 if [ $UID != 0 ]; then
13 echo $msg must be run as root >&2
19 SYSFS=`mount -t sysfs | head -1 | awk '{ print $3 }'`
21 if [ ! -d "$SYSFS" ]; then
22 echo $msg sysfs is not mounted >&2
26 if ! ls $SYSFS/devices/system/cpu/cpu* > /dev/null 2>&1; then
27 echo $msg cpu hotplug is not supported >&2
31 echo "CPU online/offline summary:"
32 online_cpus=`cat $SYSFS/devices/system/cpu/online`
33 online_max=${online_cpus##*-}
35 if [[ "$online_cpus" = "$online_max" ]]; then
36 echo "$msg: since there is only one cpu: $online_cpus"
40 present_cpus=`cat $SYSFS/devices/system/cpu/present`
41 present_max=${present_cpus##*-}
42 echo "present_cpus = $present_cpus present_max = $present_max"
44 echo -e "\t Cpus in online state: $online_cpus"
46 offline_cpus=`cat $SYSFS/devices/system/cpu/offline`
47 if [[ "a$offline_cpus" = "a" ]]; then
50 offline_max=${offline_cpus##*-}
52 echo -e "\t Cpus in offline state: $offline_cpus"
56 # list all hot-pluggable CPUs
62 for cpu in $SYSFS/devices/system/cpu/cpu*; do
63 if [ -f $cpu/online ] && grep -q $state $cpu/online; then
69 hotplaggable_offline_cpus()
74 hotpluggable_online_cpus()
81 grep -q 1 $SYSFS/devices/system/cpu/cpu$1/online
86 grep -q 0 $SYSFS/devices/system/cpu/cpu$1/online
91 echo 1 > $SYSFS/devices/system/cpu/cpu$1/online
96 echo 0 > $SYSFS/devices/system/cpu/cpu$1/online
99 online_cpu_expect_success()
103 if ! online_cpu $cpu; then
104 echo $FUNCNAME $cpu: unexpected fail >&2
106 elif ! cpu_is_online $cpu; then
107 echo $FUNCNAME $cpu: unexpected offline >&2
112 online_cpu_expect_fail()
116 if online_cpu $cpu 2> /dev/null; then
117 echo $FUNCNAME $cpu: unexpected success >&2
119 elif ! cpu_is_offline $cpu; then
120 echo $FUNCNAME $cpu: unexpected online >&2
125 offline_cpu_expect_success()
129 if ! offline_cpu $cpu; then
130 echo $FUNCNAME $cpu: unexpected fail >&2
132 elif ! cpu_is_offline $cpu; then
133 echo $FUNCNAME $cpu: unexpected offline >&2
138 offline_cpu_expect_fail()
142 if offline_cpu $cpu 2> /dev/null; then
143 echo $FUNCNAME $cpu: unexpected success >&2
145 elif ! cpu_is_online $cpu; then
146 echo $FUNCNAME $cpu: unexpected offline >&2
161 while getopts e:ahp: opt; do
170 echo "Usage $0 [ -a ] [ -e errno ] [ -p notifier-priority ]"
171 echo -e "\t default offline one cpu"
172 echo -e "\t run with -a option to offline all cpus"
181 if ! [ "$error" -ge -4095 -a "$error" -lt 0 ]; then
182 echo "error code must be -4095 <= errno < 0" >&2
189 # Safe test (default) - offline and online one cpu
191 if [ $allcpus -eq 0 ]; then
192 echo "Limited scope test: one hotplug cpu"
193 echo -e "\t (leaves cpu in the original state):"
194 echo -e "\t online to offline to online: cpu $online_max"
195 offline_cpu_expect_success $online_max
196 online_cpu_expect_success $online_max
198 if [[ $offline_cpus -gt 0 ]]; then
199 echo -e "\t offline to online to offline: cpu $present_max"
200 online_cpu_expect_success $present_max
201 offline_cpu_expect_success $present_max
202 online_cpu $present_max
206 echo "Full scope test: all hotplug cpus"
207 echo -e "\t online all offline cpus"
208 echo -e "\t offline all online cpus"
209 echo -e "\t online all offline cpus"
213 # Online all hot-pluggable CPUs
215 for cpu in `hotplaggable_offline_cpus`; do
216 online_cpu_expect_success $cpu
220 # Offline all hot-pluggable CPUs
222 for cpu in `hotpluggable_online_cpus`; do
223 offline_cpu_expect_success $cpu
227 # Online all hot-pluggable CPUs again
229 for cpu in `hotplaggable_offline_cpus`; do
230 online_cpu_expect_success $cpu
234 # Test with cpu notifier error injection
237 DEBUGFS=`mount -t debugfs | head -1 | awk '{ print $3 }'`
238 NOTIFIER_ERR_INJECT_DIR=$DEBUGFS/notifier-error-inject/cpu
242 msg="skip extra tests:"
244 /sbin/modprobe -q -r cpu-notifier-error-inject
245 /sbin/modprobe -q cpu-notifier-error-inject priority=$priority
247 if [ ! -d "$DEBUGFS" ]; then
248 echo $msg debugfs is not mounted >&2
252 if [ ! -d $NOTIFIER_ERR_INJECT_DIR ]; then
253 echo $msg cpu-notifier-error-inject module is not available >&2
261 # Offline all hot-pluggable CPUs
263 echo 0 > $NOTIFIER_ERR_INJECT_DIR/actions/CPU_DOWN_PREPARE/error
264 for cpu in `hotpluggable_online_cpus`; do
265 offline_cpu_expect_success $cpu
269 # Test CPU hot-add error handling (offline => online)
271 echo $error > $NOTIFIER_ERR_INJECT_DIR/actions/CPU_UP_PREPARE/error
272 for cpu in `hotplaggable_offline_cpus`; do
273 online_cpu_expect_fail $cpu
277 # Online all hot-pluggable CPUs
279 echo 0 > $NOTIFIER_ERR_INJECT_DIR/actions/CPU_UP_PREPARE/error
280 for cpu in `hotplaggable_offline_cpus`; do
281 online_cpu_expect_success $cpu
285 # Test CPU hot-remove error handling (online => offline)
287 echo $error > $NOTIFIER_ERR_INJECT_DIR/actions/CPU_DOWN_PREPARE/error
288 for cpu in `hotpluggable_online_cpus`; do
289 offline_cpu_expect_fail $cpu
292 echo 0 > $NOTIFIER_ERR_INJECT_DIR/actions/CPU_DOWN_PREPARE/error
293 /sbin/modprobe -q -r cpu-notifier-error-inject