blob: 61f9a32d3368e7efed72463091f4d38bf12a8e39 [file] [log] [blame]
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0
#please run as root
# Kselftest framework requirement - SKIP code is 4.
ksft_skip=4
mnt=./huge
exitcode=0
##get huge pagesize and freepages from /proc/meminfo
#while read name size unit; do
# if [ "$name" = "HugePages_Free:" ]; then
# freepgs=$size
# fi
# if [ "$name" = "Hugepagesize:" ]; then
# hpgsize_KB=$size
# fi
#done < /proc/meminfo
#
## Simple hugetlbfs tests have a hardcoded minimum requirement of
## huge pages totaling 256MB (262144KB) in size. The userfaultfd
## hugetlb test requires a minimum of 2 * nr_cpus huge pages. Take
## both of these requirements into account and attempt to increase
## number of huge pages available.
#nr_cpus=$(nproc)
#hpgsize_MB=$((hpgsize_KB / 1024))
#half_ufd_size_MB=$((((nr_cpus * hpgsize_MB + 127) / 128) * 128))
#needmem_KB=$((half_ufd_size_MB * 2 * 1024))
#
##set proper nr_hugepages
#if [ -n "$freepgs" ] && [ -n "$hpgsize_KB" ]; then
# nr_hugepgs=`cat /proc/sys/vm/nr_hugepages`
# needpgs=$((needmem_KB / hpgsize_KB))
# tries=2
# while [ $tries -gt 0 ] && [ $freepgs -lt $needpgs ]; do
# lackpgs=$(( $needpgs - $freepgs ))
# echo 3 > /proc/sys/vm/drop_caches
# echo $(( $lackpgs + $nr_hugepgs )) > /proc/sys/vm/nr_hugepages
# if [ $? -ne 0 ]; then
# echo "Please run this test as root"
# exit $ksft_skip
# fi
# while read name size unit; do
# if [ "$name" = "HugePages_Free:" ]; then
# freepgs=$size
# fi
# done < /proc/meminfo
# tries=$((tries - 1))
# done
# if [ $freepgs -lt $needpgs ]; then
# printf "Not enough huge pages available (%d < %d)\n" \
# $freepgs $needpgs
# exit 1
# fi
#else
# echo "no hugetlbfs support in kernel?"
# exit 1
#fi
#
##filter 64bit architectures
#ARCH64STR="arm64 ia64 mips64 parisc64 ppc64 riscv64 s390x sh64 sparc64 x86_64"
#if [ -z $ARCH ]; then
# ARCH=`uname -m 2>/dev/null | sed -e 's/aarch64.*/arm64/'`
#fi
#VADDR64=0
#echo "$ARCH64STR" | grep $ARCH && VADDR64=1
#
#mkdir $mnt
#mount -t hugetlbfs none $mnt
#
#echo "---------------------"
#echo "running hugepage-mmap"
#echo "---------------------"
#./hugepage-mmap
#if [ $? -ne 0 ]; then
# echo "[FAIL]"
# exitcode=1
#else
# echo "[PASS]"
#fi
#
#shmmax=`cat /proc/sys/kernel/shmmax`
#shmall=`cat /proc/sys/kernel/shmall`
#echo 268435456 > /proc/sys/kernel/shmmax
#echo 4194304 > /proc/sys/kernel/shmall
#echo "--------------------"
#echo "running hugepage-shm"
#echo "--------------------"
#./hugepage-shm
#if [ $? -ne 0 ]; then
# echo "[FAIL]"
# exitcode=1
#else
# echo "[PASS]"
#fi
#echo $shmmax > /proc/sys/kernel/shmmax
#echo $shmall > /proc/sys/kernel/shmall
#
#echo "-------------------"
#echo "running map_hugetlb"
#echo "-------------------"
#./map_hugetlb
#if [ $? -ne 0 ]; then
# echo "[FAIL]"
# exitcode=1
#else
# echo "[PASS]"
#fi
#
#echo "NOTE: The above hugetlb tests provide minimal coverage. Use"
#echo " https://github.com/libhugetlbfs/libhugetlbfs.git for"
#echo " hugetlb regression testing."
#
#echo "-------------------"
#echo "running userfaultfd"
#echo "-------------------"
#./userfaultfd anon 128 32
#if [ $? -ne 0 ]; then
# echo "[FAIL]"
# exitcode=1
#else
# echo "[PASS]"
#fi
#
#echo "---------------------------"
#echo "running userfaultfd_hugetlb"
#echo "---------------------------"
## Test requires source and destination huge pages. Size of source
## (half_ufd_size_MB) is passed as argument to test.
#./userfaultfd hugetlb $half_ufd_size_MB 32 $mnt/ufd_test_file
#if [ $? -ne 0 ]; then
# echo "[FAIL]"
# exitcode=1
#else
# echo "[PASS]"
#fi
#rm -f $mnt/ufd_test_file
#
#echo "-------------------------"
#echo "running userfaultfd_shmem"
#echo "-------------------------"
#./userfaultfd shmem 128 32
#if [ $? -ne 0 ]; then
# echo "[FAIL]"
# exitcode=1
#else
# echo "[PASS]"
#fi
#
##cleanup
#umount $mnt
#rm -rf $mnt
#echo $nr_hugepgs > /proc/sys/vm/nr_hugepages
#
#echo "-----------------------"
#echo "running compaction_test"
#echo "-----------------------"
#./compaction_test
#if [ $? -ne 0 ]; then
# echo "[FAIL]"
# exitcode=1
#else
# echo "[PASS]"
#fi
echo "----------------------"
echo "running on-fault-limit"
echo "----------------------"
sudo -u nobody ./on-fault-limit
if [ $? -ne 0 ]; then
echo "[FAIL]"
exitcode=1
else
echo "[PASS]"
fi
echo "--------------------"
echo "running map_populate"
echo "--------------------"
./map_populate
if [ $? -ne 0 ]; then
echo "[FAIL]"
exitcode=1
else
echo "[PASS]"
fi
echo "--------------------"
echo "running mlock2-tests"
echo "--------------------"
./mlock2-tests
if [ $? -ne 0 ]; then
echo "[FAIL]"
exitcode=1
else
echo "[PASS]"
fi
if [ $VADDR64 -ne 0 ]; then
echo "-----------------------------"
echo "running virtual_address_range"
echo "-----------------------------"
./virtual_address_range
if [ $? -ne 0 ]; then
echo "[FAIL]"
exitcode=1
else
echo "[PASS]"
fi
echo "-----------------------------"
echo "running virtual address 128TB switch test"
echo "-----------------------------"
./va_128TBswitch
if [ $? -ne 0 ]; then
echo "[FAIL]"
exitcode=1
else
echo "[PASS]"
fi
fi # VADDR64
echo "------------------------------------"
echo "running vmalloc stability smoke test"
echo "------------------------------------"
./test_vmalloc.sh smoke
ret_val=$?
if [ $ret_val -eq 0 ]; then
echo "[PASS]"
elif [ $ret_val -eq $ksft_skip ]; then
echo "[SKIP]"
exitcode=$ksft_skip
else
echo "[FAIL]"
exitcode=1
fi
exit $exitcode