On 4/29/26 2:12 AM, Mike Rapoport wrote:
> From: "Mike Rapoport (Microsoft)" <[email protected]>
>
> Convert uffd-stress test to use kselftest framework for reporting and
> tracking successful and failing runs.
>
> Reviewed-by: Mark Brown <[email protected]>
> Signed-off-by: Mike Rapoport (Microsoft) <[email protected]>
I've run the test before and after applying the patch. The patch
correctly formats the output according to KTAP format with no change in
results.
Tested-by: Sarthak Sharma <[email protected]>
> ---
> tools/testing/selftests/mm/uffd-stress.c | 41 +++++++++++-------------
> 1 file changed, 19 insertions(+), 22 deletions(-)
>
> diff --git a/tools/testing/selftests/mm/uffd-stress.c
> b/tools/testing/selftests/mm/uffd-stress.c
> index 700fbaa18d44..e92a85463eb1 100644
> --- a/tools/testing/selftests/mm/uffd-stress.c
> +++ b/tools/testing/selftests/mm/uffd-stress.c
> @@ -286,19 +286,12 @@ static int userfaultfd_stress(uffd_global_test_opts_t
> *gopts)
> pthread_attr_setstacksize(&attr, 16*1024*1024);
>
> while (bounces--) {
> - printf("bounces: %d, mode:", bounces);
> - if (bounces & BOUNCE_RANDOM)
> - printf(" rnd");
> - if (bounces & BOUNCE_RACINGFAULTS)
> - printf(" racing");
> - if (bounces & BOUNCE_VERIFY)
> - printf(" ver");
> - if (bounces & BOUNCE_POLL)
> - printf(" poll");
> - else
> - printf(" read");
> - printf(", ");
> - fflush(stdout);
> + ksft_print_msg("bounces: %d, mode:%s%s%s%s, ",
> + bounces,
> + bounces & BOUNCE_RANDOM ? " rnd" : "",
> + bounces & BOUNCE_RACINGFAULTS ? " racing" : "",
> + bounces & BOUNCE_VERIFY ? " ver" : "",
> + bounces & BOUNCE_POLL ? " poll" : " read");
>
> if (bounces & BOUNCE_POLL)
> fcntl(gopts->uffd, F_SETFL, gopts->uffd_flags |
> O_NONBLOCK);
> @@ -456,6 +449,9 @@ int main(int argc, char **argv)
> unsigned long nr_cpus;
> size_t bytes;
>
> + ksft_print_header();
> + ksft_set_plan(1);
> +
> gopts = (uffd_global_test_opts_t *)
> malloc(sizeof(uffd_global_test_opts_t));
>
> if (argc < 4)
> @@ -484,10 +480,8 @@ int main(int argc, char **argv)
> * for racy extra reservation of hugepages.
> */
> if (gopts->test_type == TEST_HUGETLB &&
> - get_free_hugepages() < 2 * (bytes / gopts->page_size) +
> gopts->nr_parallel - 1) {
> - printf("skip: Skipping userfaultfd... not enough hugepages\n");
> - return KSFT_SKIP;
> - }
> + get_free_hugepages() < 2 * (bytes / gopts->page_size) +
> gopts->nr_parallel - 1)
> + ksft_exit_skip("Skipping userfaultfd... not enough
> hugepages\n");
>
> gopts->nr_pages_per_cpu = bytes / gopts->page_size / gopts->nr_parallel;
> if (!gopts->nr_pages_per_cpu) {
> @@ -503,9 +497,12 @@ int main(int argc, char **argv)
> }
> gopts->nr_pages = gopts->nr_pages_per_cpu * gopts->nr_parallel;
>
> - printf("nr_pages: %lu, nr_pages_per_cpu: %lu\n",
> - gopts->nr_pages, gopts->nr_pages_per_cpu);
> - return userfaultfd_stress(gopts);
> + ksft_print_msg("nr_pages: %lu, nr_pages_per_cpu: %lu\n",
> + gopts->nr_pages, gopts->nr_pages_per_cpu);
> +
> + ksft_test_result(!userfaultfd_stress(gopts),
> + "uffd-stress %s\n", argv[1]);
> + ksft_finished();
> }
>
> #else /* __NR_userfaultfd */
> @@ -514,8 +511,8 @@ int main(int argc, char **argv)
>
> int main(void)
> {
> - printf("skip: Skipping userfaultfd test (missing __NR_userfaultfd)\n");
> - return KSFT_SKIP;
> + ksft_print_header();
> + ksft_exit_skip("missing __NR_userfaultfd definition\n");
> }
>
> #endif /* __NR_userfaultfd */