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 "$*")