On 4/29/26 2:12 AM, Mike Rapoport wrote: > From: "Mike Rapoport (Microsoft)" <[email protected]> > > Currently when running THP and HugeTLB tests, if HAVE_HUGEPAGES is set > run_test() drops caches, compacts memory and runs the test. But if > HAVE_HUGEPAGES is not set it skips the tests entirely, even if THP tests > have nothing to do with HAVE_HUGEPAGES. > > Replace the check if HAVE_HUGEPAGES is set with a check of how much memory > is available. If there is less than 256 MB of available memory, drop caches > and run compaction and then continue to run a test regardless of > HAVE_HUGEPAGES value. > > Signed-off-by: Mike Rapoport (Microsoft) <[email protected]> This patch looks good to me. Reviewed-by: Sarthak Sharma <[email protected]> > --- > tools/testing/selftests/mm/run_vmtests.sh | 18 +++++++++--------- > 1 file changed, 9 insertions(+), 9 deletions(-) > > diff --git a/tools/testing/selftests/mm/run_vmtests.sh > b/tools/testing/selftests/mm/run_vmtests.sh > index b9e520194634..b42d19036182 100755 > --- a/tools/testing/selftests/mm/run_vmtests.sh > +++ b/tools/testing/selftests/mm/run_vmtests.sh > @@ -99,6 +99,9 @@ EOF > exit 0 > } > > +mem_available_kb=$(awk '/MemAvailable/ {print $2}' /proc/meminfo) > +mem_available_Mb=$((mem_available_kb / 1024)) > + > RUN_ALL=false > RUN_DESTRUCTIVE=false > TAP_PREFIX="# " > @@ -239,15 +242,12 @@ run_test() { > # On memory constrainted systems some tests can fail to > allocate hugepages. > # perform some cleanup before the test for a higher success > rate. > if [ ${CATEGORY} == "thp" -o ${CATEGORY} == "hugetlb" ]; then > - if [ "${HAVE_HUGEPAGES}" = "1" ]; then > - echo 3 > /proc/sys/vm/drop_caches > - sleep 2 > - echo 1 > /proc/sys/vm/compact_memory > - sleep 2 > - else > - echo "hugepages not supported" | tap_prefix > - skip=1 > - fi > + if (( $mem_available_Mb < 256 )); then > + echo 3 > /proc/sys/vm/drop_caches > + sleep 2 > + echo 1 > /proc/sys/vm/compact_memory > + sleep 2 > + fi > fi > > local test=$(pretty_name "$*")

