Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

selftests/zram: Adapt the situation that /dev/zram0 is being used

If zram-generator package is installed and works, then we can not remove
zram module because zram swap is being used. This case needs a clean zram
environment, change this test by using hot_add/hot_remove interface. So
even zram device is being used, we still can add zram device and remove
them in cleanup.

The two interface was introduced since kernel commit 6566d1a32bf7("zram:
add dynamic device add/remove functionality") in v4.2-rc1. If kernel
supports these two interface, we use hot_add/hot_remove to slove this
problem, if not, just check whether zram is being used or built in, then
skip it on old kernel.

Signed-off-by: Yang Xu <xuyang2018.jy@fujitsu.com>
Signed-off-by: Shuah Khan <skhan@linuxfoundation.org>

authored by

Yang Xu and committed by
Shuah Khan
01dabed2 d18da7ec

+67 -64
+1 -14
tools/testing/selftests/zram/zram.sh
··· 2 2 # SPDX-License-Identifier: GPL-2.0 3 3 TCID="zram.sh" 4 4 5 - # Kselftest framework requirement - SKIP code is 4. 6 - ksft_skip=4 7 - 8 5 . ./zram_lib.sh 9 6 10 7 run_zram () { ··· 15 18 16 19 check_prereqs 17 20 18 - # check zram module exists 19 - MODULE_PATH=/lib/modules/`uname -r`/kernel/drivers/block/zram/zram.ko 20 - if [ -f $MODULE_PATH ]; then 21 - run_zram 22 - elif [ -b /dev/zram0 ]; then 23 - run_zram 24 - else 25 - echo "$TCID : No zram.ko module or /dev/zram0 device file not found" 26 - echo "$TCID : CONFIG_ZRAM is not set" 27 - exit $ksft_skip 28 - fi 21 + run_zram
+1 -2
tools/testing/selftests/zram/zram01.sh
··· 33 33 34 34 zram_fill_fs() 35 35 { 36 - for i in $(seq 0 $(($dev_num - 1))); do 36 + for i in $(seq $dev_start $dev_end); do 37 37 echo "fill zram$i..." 38 38 local b=0 39 39 while [ true ]; do ··· 67 67 68 68 zram_fill_fs 69 69 zram_cleanup 70 - zram_unload 71 70 72 71 if [ $ERR_CODE -ne 0 ]; then 73 72 echo "$TCID : [FAIL]"
-1
tools/testing/selftests/zram/zram02.sh
··· 36 36 zram_makeswap 37 37 zram_swapoff 38 38 zram_cleanup 39 - zram_unload 40 39 41 40 if [ $ERR_CODE -ne 0 ]; then 42 41 echo "$TCID : [FAIL]"
+65 -47
tools/testing/selftests/zram/zram_lib.sh
··· 5 5 # Author: Alexey Kodanev <alexey.kodanev@oracle.com> 6 6 # Modified: Naresh Kamboju <naresh.kamboju@linaro.org> 7 7 8 - MODULE=0 9 8 dev_makeswap=-1 10 9 dev_mounted=-1 11 - 10 + dev_start=0 11 + dev_end=-1 12 + module_load=-1 13 + sys_control=-1 12 14 # Kselftest framework requirement - SKIP code is 4. 13 15 ksft_skip=4 14 16 kernel_version=`uname -r | cut -d'.' -f1,2` ··· 48 46 { 49 47 echo "zram cleanup" 50 48 local i= 51 - for i in $(seq 0 $dev_makeswap); do 49 + for i in $(seq $dev_start $dev_makeswap); do 52 50 swapoff /dev/zram$i 53 51 done 54 52 55 - for i in $(seq 0 $dev_mounted); do 53 + for i in $(seq $dev_start $dev_mounted); do 56 54 umount /dev/zram$i 57 55 done 58 56 59 - for i in $(seq 0 $(($dev_num - 1))); do 57 + for i in $(seq $dev_start $dev_end); do 60 58 echo 1 > /sys/block/zram${i}/reset 61 59 rm -rf zram$i 62 60 done 63 61 64 - } 62 + if [ $sys_control -eq 1 ]; then 63 + for i in $(seq $dev_start $dev_end); do 64 + echo $i > /sys/class/zram-control/hot_remove 65 + done 66 + fi 65 67 66 - zram_unload() 67 - { 68 - if [ $MODULE -ne 0 ] ; then 69 - echo "zram rmmod zram" 68 + if [ $module_load -eq 1 ]; then 70 69 rmmod zram > /dev/null 2>&1 71 70 fi 72 71 } 73 72 74 73 zram_load() 75 74 { 76 - # check zram module exists 77 - MODULE_PATH=/lib/modules/`uname -r`/kernel/drivers/block/zram/zram.ko 78 - if [ -f $MODULE_PATH ]; then 79 - MODULE=1 80 - echo "create '$dev_num' zram device(s)" 81 - modprobe zram num_devices=$dev_num 82 - if [ $? -ne 0 ]; then 83 - echo "failed to insert zram module" 84 - exit 1 85 - fi 75 + echo "create '$dev_num' zram device(s)" 86 76 87 - dev_num_created=$(ls /dev/zram* | wc -w) 77 + # zram module loaded, new kernel 78 + if [ -d "/sys/class/zram-control" ]; then 79 + echo "zram modules already loaded, kernel supports" \ 80 + "zram-control interface" 81 + dev_start=$(ls /dev/zram* | wc -w) 82 + dev_end=$(($dev_start + $dev_num - 1)) 83 + sys_control=1 88 84 89 - if [ "$dev_num_created" -ne "$dev_num" ]; then 90 - echo "unexpected num of devices: $dev_num_created" 91 - ERR_CODE=-1 92 - else 93 - echo "zram load module successful" 94 - fi 95 - elif [ -b /dev/zram0 ]; then 96 - echo "/dev/zram0 device file found: OK" 97 - else 98 - echo "ERROR: No zram.ko module or no /dev/zram0 device found" 99 - echo "$TCID : CONFIG_ZRAM is not set" 100 - exit 1 85 + for i in $(seq $dev_start $dev_end); do 86 + cat /sys/class/zram-control/hot_add > /dev/null 87 + done 88 + 89 + echo "all zram devices (/dev/zram$dev_start~$dev_end" \ 90 + "successfully created" 91 + return 0 101 92 fi 93 + 94 + # detect old kernel or built-in 95 + modprobe zram num_devices=$dev_num 96 + if [ ! -d "/sys/class/zram-control" ]; then 97 + if grep -q '^zram' /proc/modules; then 98 + rmmod zram > /dev/null 2>&1 99 + if [ $? -ne 0 ]; then 100 + echo "zram module is being used on old kernel" \ 101 + "without zram-control interface" 102 + exit $ksft_skip 103 + fi 104 + else 105 + echo "test needs CONFIG_ZRAM=m on old kernel without" \ 106 + "zram-control interface" 107 + exit $ksft_skip 108 + fi 109 + modprobe zram num_devices=$dev_num 110 + fi 111 + 112 + module_load=1 113 + dev_end=$(($dev_num - 1)) 114 + echo "all zram devices (/dev/zram0~$dev_end) successfully created" 102 115 } 103 116 104 117 zram_max_streams() ··· 127 110 return 0 128 111 fi 129 112 130 - local i=0 113 + local i=$dev_start 131 114 for max_s in $zram_max_streams; do 132 115 local sys_path="/sys/block/zram${i}/max_comp_streams" 133 116 echo $max_s > $sys_path || \ ··· 139 122 echo "FAIL can't set max_streams '$max_s', get $max_stream" 140 123 141 124 i=$(($i + 1)) 142 - echo "$sys_path = '$max_streams' ($i/$dev_num)" 125 + echo "$sys_path = '$max_streams'" 143 126 done 144 127 145 128 echo "zram max streams: OK" ··· 149 132 { 150 133 echo "test that we can set compression algorithm" 151 134 152 - local algs=$(cat /sys/block/zram0/comp_algorithm) 135 + local i=$dev_start 136 + local algs=$(cat /sys/block/zram${i}/comp_algorithm) 153 137 echo "supported algs: $algs" 154 - local i=0 138 + 155 139 for alg in $zram_algs; do 156 140 local sys_path="/sys/block/zram${i}/comp_algorithm" 157 141 echo "$alg" > $sys_path || \ 158 142 echo "FAIL can't set '$alg' to $sys_path" 159 143 i=$(($i + 1)) 160 - echo "$sys_path = '$alg' ($i/$dev_num)" 144 + echo "$sys_path = '$alg'" 161 145 done 162 146 163 147 echo "zram set compression algorithm: OK" ··· 167 149 zram_set_disksizes() 168 150 { 169 151 echo "set disk size to zram device(s)" 170 - local i=0 152 + local i=$dev_start 171 153 for ds in $zram_sizes; do 172 154 local sys_path="/sys/block/zram${i}/disksize" 173 155 echo "$ds" > $sys_path || \ 174 156 echo "FAIL can't set '$ds' to $sys_path" 175 157 176 158 i=$(($i + 1)) 177 - echo "$sys_path = '$ds' ($i/$dev_num)" 159 + echo "$sys_path = '$ds'" 178 160 done 179 161 180 162 echo "zram set disksizes: OK" ··· 184 166 { 185 167 echo "set memory limit to zram device(s)" 186 168 187 - local i=0 169 + local i=$dev_start 188 170 for ds in $zram_mem_limits; do 189 171 local sys_path="/sys/block/zram${i}/mem_limit" 190 172 echo "$ds" > $sys_path || \ 191 173 echo "FAIL can't set '$ds' to $sys_path" 192 174 193 175 i=$(($i + 1)) 194 - echo "$sys_path = '$ds' ($i/$dev_num)" 176 + echo "$sys_path = '$ds'" 195 177 done 196 178 197 179 echo "zram set memory limit: OK" ··· 200 182 zram_makeswap() 201 183 { 202 184 echo "make swap with zram device(s)" 203 - local i=0 204 - for i in $(seq 0 $(($dev_num - 1))); do 185 + local i=$dev_start 186 + for i in $(seq $dev_start $dev_end); do 205 187 mkswap /dev/zram$i > err.log 2>&1 206 188 if [ $? -ne 0 ]; then 207 189 cat err.log ··· 224 206 zram_swapoff() 225 207 { 226 208 local i= 227 - for i in $(seq 0 $dev_makeswap); do 209 + for i in $(seq $dev_start $dev_end); do 228 210 swapoff /dev/zram$i > err.log 2>&1 229 211 if [ $? -ne 0 ]; then 230 212 cat err.log ··· 238 220 239 221 zram_makefs() 240 222 { 241 - local i=0 223 + local i=$dev_start 242 224 for fs in $zram_filesystems; do 243 225 # if requested fs not supported default it to ext2 244 226 which mkfs.$fs > /dev/null 2>&1 || fs=ext2 ··· 257 239 zram_mount() 258 240 { 259 241 local i=0 260 - for i in $(seq 0 $(($dev_num - 1))); do 242 + for i in $(seq $dev_start $dev_end); do 261 243 echo "mount /dev/zram$i" 262 244 mkdir zram$i 263 245 mount /dev/zram$i zram$i > /dev/null || \