From: Mike Rapoport <rppt@kernel.org>
To: Chunyu Hu <chuhu@redhat.com>
Cc: akpm@linux-foundation.org, david@kernel.org, shuah@kernel.org,
linux-mm@kvack.org, ljs@kernel.org,
linux-kselftest@vger.kernel.org, linux-kernel@vger.kernel.org,
lorenzo.stoakes@oracle.com, Liam.Howlett@oracle.com,
vbabka@suse.cz, surenb@google.com, mhocko@suse.com,
ziy@nvidia.com, baolin.wang@linux.alibaba.com, npache@redhat.com,
ryan.roberts@arm.com, dev.jain@arm.com, baohua@kernel.org,
lance.yang@linux.dev, Li Wang <liwang@redhat.com>
Subject: Re: [PATCH v4 1/5] selftests/mm/guard-regions: skip collapse test when thp not enabled
Date: Thu, 19 Mar 2026 19:21:03 +0200 [thread overview]
Message-ID: <abwwf6WlLwdQDBE0@kernel.org> (raw)
In-Reply-To: <20260319160656.1480279-2-chuhu@redhat.com>
On Fri, Mar 20, 2026 at 12:06:52AM +0800, Chunyu Hu wrote:
> When thp is not available, just skip the collape tests to avoid the false
> negative.
>
> Without the change, run with a thp disabled kernel:
> ./run_vmtests.sh -t madv_guard -n 1
> <snip/>
> # RUN guard_regions.anon.collapse ...
> # guard-regions.c:2217:collapse:Expected madvise(ptr, size, MADV_NOHUGEPAGE) (-1) == 0 (0)
> # collapse: Test terminated by assertion
> # FAIL guard_regions.anon.collapse
> not ok 2 guard_regions.anon.collapse
> <snip/>
> # RUN guard_regions.shmem.collapse ...
> # guard-regions.c:2217:collapse:Expected madvise(ptr, size, MADV_NOHUGEPAGE) (-1) == 0 (0)
> # collapse: Test terminated by assertion
> # FAIL guard_regions.shmem.collapse
> not ok 32 guard_regions.shmem.collapse
> <snip/>
> # RUN guard_regions.file.collapse ...
> # guard-regions.c:2217:collapse:Expected madvise(ptr, size, MADV_NOHUGEPAGE) (-1) == 0 (0)
> # collapse: Test terminated by assertion
> # FAIL guard_regions.file.collapse
> not ok 62 guard_regions.file.collapse
> <snip/>
> # FAILED: 87 / 90 tests passed.
> # 17 skipped test(s) detected. Consider enabling relevant config options to improve coverage.
> # Totals: pass:70 fail:3 xfail:0 xpass:0 skip:17 error:0
>
> With this change, run with thp disabled kernel:
> ./run_vmtests.sh -t madv_guard -n 1
> <snip/>
> # RUN guard_regions.anon.collapse ...
> # SKIP Transparent Hugepages not available
> # OK guard_regions.anon.collapse
> ok 2 guard_regions.anon.collapse # SKIP Transparent Hugepages not available
> <snip/>
> # RUN guard_regions.file.collapse ...
> # SKIP Transparent Hugepages not available
> # OK guard_regions.file.collapse
> ok 62 guard_regions.file.collapse # SKIP Transparent Hugepages not available
> <snip/>
> # RUN guard_regions.shmem.collapse ...
> # SKIP Transparent Hugepages not available
> # OK guard_regions.shmem.collapse
> ok 32 guard_regions.shmem.collapse # SKIP Transparent Hugepages not available
> <snip/>
> # PASSED: 90 / 90 tests passed.
> # 20 skipped test(s) detected. Consider enabling relevant config options to improve coverage.
> # Totals: pass:70 fail:0 xfail:0 xpass:0 skip:20 error:0
>
> CC: Li Wang <liwang@redhat.com>
> Signed-off-by: Chunyu Hu <chuhu@redhat.com>
Acked-by: Mike Rapoport (Microsoft) <rppt@kernel.org>
> ---
> Changes in v4:
> - use thp_available instead of thp_is_enabled() as when thp is set to
> never, madvise(MADV_COLLAPSE) will still succeed by design. So a
> failure in madvise(MADV_COLLAPSE) on guard region will verify guard
> region denies it. This is suggested from AI.
> - removed the 'Reviewed-by' and 'Acked-by' as the code changes. Sorry for
> that but it seems the changes is a little huge? (1 out of 2 lines)..
> Changes in v3:
> - commit message: update the log snippet with where the fail happens and
> add the '-n1' to the command.
> - fix the 'false positive' to 'false negative'
> - add reviwed by from Mike
> Changes in v2:
> - add reviewed by from Zi and Lorenzo
> - add acked-by from David
> ---
> tools/testing/selftests/mm/guard-regions.c | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/tools/testing/selftests/mm/guard-regions.c b/tools/testing/selftests/mm/guard-regions.c
> index dbd21d66d383..48e8b1539be3 100644
> --- a/tools/testing/selftests/mm/guard-regions.c
> +++ b/tools/testing/selftests/mm/guard-regions.c
> @@ -21,6 +21,7 @@
> #include <sys/uio.h>
> #include <unistd.h>
> #include "vm_util.h"
> +#include "thp_settings.h"
>
> #include "../pidfd/pidfd.h"
>
> @@ -2195,6 +2196,9 @@ TEST_F(guard_regions, collapse)
> char *ptr;
> int i;
>
> + if (!thp_available())
> + SKIP(return, "Transparent Hugepages not available\n");
> +
> /* Need file to be correct size for tests for non-anon. */
> if (variant->backing != ANON_BACKED)
> ASSERT_EQ(ftruncate(self->fd, size), 0);
>
> base-commit: 8a30aeb0d1b4e4aaf7f7bae72f20f2ae75385ccb
> --
> 2.53.0
>
--
Sincerely yours,
Mike.
next prev parent reply other threads:[~2026-03-19 17:21 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-03-19 16:06 [PATCH v4 0/5] selftests/mm: skip several tests when thp is not available Chunyu Hu
2026-03-19 16:06 ` [PATCH v4 1/5] selftests/mm/guard-regions: skip collapse test when thp not enabled Chunyu Hu
2026-03-19 17:21 ` Mike Rapoport [this message]
2026-03-19 19:05 ` Zi Yan
2026-03-19 21:46 ` David Hildenbrand (Arm)
2026-03-19 16:06 ` [PATCH v4 2/5] selftests/mm: soft-dirty: skip two tests when thp is not available Chunyu Hu
2026-03-19 16:06 ` [PATCH v4 3/5] selftests/mm: move write_file helper to vm_util Chunyu Hu
2026-03-19 17:20 ` Mike Rapoport
2026-03-19 19:06 ` Zi Yan
2026-03-19 21:48 ` David Hildenbrand (Arm)
2026-03-23 3:10 ` Chunyu Hu
2026-03-19 16:06 ` [PATCH v4 4/5] selftests/mm: split_huge_page_test: skip the test when thp is not available Chunyu Hu
2026-03-19 16:06 ` [PATCH v4 5/5] selftests/mm: transhuge_stress: skip the test when thp " Chunyu Hu
2026-03-20 2:46 ` [PATCH v4 0/5] selftests/mm: skip several tests when thp is " Andrew Morton
2026-03-23 3:21 ` Chunyu Hu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=abwwf6WlLwdQDBE0@kernel.org \
--to=rppt@kernel.org \
--cc=Liam.Howlett@oracle.com \
--cc=akpm@linux-foundation.org \
--cc=baohua@kernel.org \
--cc=baolin.wang@linux.alibaba.com \
--cc=chuhu@redhat.com \
--cc=david@kernel.org \
--cc=dev.jain@arm.com \
--cc=lance.yang@linux.dev \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=liwang@redhat.com \
--cc=ljs@kernel.org \
--cc=lorenzo.stoakes@oracle.com \
--cc=mhocko@suse.com \
--cc=npache@redhat.com \
--cc=ryan.roberts@arm.com \
--cc=shuah@kernel.org \
--cc=surenb@google.com \
--cc=vbabka@suse.cz \
--cc=ziy@nvidia.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox