#!/bin/sh # Copyright (c) 2014-2015 Oracle and/or its affiliates. All Rights Reserved. # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License as # published by the Free Software Foundation; either version 2 of # the License, or (at your option) any later version. # # This program is distributed in the hope that it would be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write the Free Software Foundation, # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA # # Author: Alexey Kodanev # # One of the possible ways to test RCU is to use rcutorture kernel module. # The test requires that kernel configured with CONFIG_RCU_TORTURE_TEST. # It runs rcutorture module using particular options and then inspects # dmesg output for module's test results. # For more information, please read Linux Documentation: RCU/torture.txt TCID="rcu_torture" TST_TOTAL=14 TST_CLEANUP=cleanup . test.sh # default options test_time=60 num_writers=5 while getopts :ht:w: opt; do case "$opt" in h) echo "Usage:" echo "h help" echo "t x time in seconds for each test-case" echo "w x number of writers" exit 0 ;; t) test_time=$OPTARG ;; w) num_writers=$OPTARG ;; *) tst_brkm TBROK "unknown option: $opt" ;; esac done cleanup() { tst_resm TINFO "cleanup" rmmod rcutorture > /dev/null 2>&1 } tst_require_root # check if module is present modprobe rcutorture > /dev/null 2>&1 || \ tst_brkm TCONF "Test requires rcutorture module" rmmod rcutorture > /dev/null 2>&1 trap cleanup INT rcu_type="rcu rcu_bh srcu sched" if tst_kvcmp -lt "3.12"; then rcu_type="$rcu_type rcu_sync rcu_expedited rcu_bh_sync rcu_bh_expedited \ srcu_sync srcu_expedited sched_sync sched_expedited" if tst_kvcmp -lt "3.11"; then rcu_type="$rcu_type srcu_raw srcu_raw_sync" fi fi TST_TOTAL=$(echo "$rcu_type" | wc -w) est_time=`echo "scale=2; $test_time * $TST_TOTAL / 60 " | bc` tst_resm TINFO "estimate time $est_time min" for type in $rcu_type; do tst_resm TINFO "$type: running $test_time sec..." modprobe rcutorture nfakewriters=$num_writers \ stat_interval=60 test_no_idle_hz=1 shuffle_interval=3 \ stutter=5 irqreader=1 fqs_duration=0 fqs_holdoff=0 \ fqs_stutter=3 test_boost=1 test_boost_interval=7 \ test_boost_duration=4 shutdown_secs=0 \ stall_cpu=0 stall_cpu_holdoff=10 n_barrier_cbs=0 \ onoff_interval=0 onoff_holdoff=0 torture_type=$type \ > /dev/null 2>&1 || tst_brkm TBROK "failed to load module" sleep $test_time rmmod rcutorture > /dev/null 2>&1 || \ tst_brkm TBROK "failed to unload module" # check module status in dmesg result_str=`dmesg | sed -nE '$s/.*End of test: ([A-Z]+):.*/\1/p'` if [ "$result_str" = "SUCCESS" ]; then tst_resm TPASS "$type: completed" else tst_resm TFAIL "$type: $result_str, see dmesg" fi done tst_exit