From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id AB8A1CD4840 for ; Mon, 11 May 2026 16:29:32 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 1FE266B00C4; Mon, 11 May 2026 12:29:32 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 1AE9D6B00C7; Mon, 11 May 2026 12:29:32 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 0EC5A6B00C8; Mon, 11 May 2026 12:29:32 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0014.hostedemail.com [216.40.44.14]) by kanga.kvack.org (Postfix) with ESMTP id F3F666B00C4 for ; Mon, 11 May 2026 12:29:31 -0400 (EDT) Received: from smtpin04.hostedemail.com (lb01a-stub [10.200.18.249]) by unirelay07.hostedemail.com (Postfix) with ESMTP id BE56E1601DB for ; Mon, 11 May 2026 16:29:31 +0000 (UTC) X-FDA: 84755674542.04.8B0F51C Received: from sea.source.kernel.org (sea.source.kernel.org [172.234.252.31]) by imf04.hostedemail.com (Postfix) with ESMTP id 0D72E4000D for ; Mon, 11 May 2026 16:29:29 +0000 (UTC) Authentication-Results: imf04.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=XqGjSiyt; spf=pass (imf04.hostedemail.com: domain of rppt@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=rppt@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1778516970; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=no6hlEu0fUwiRQ/DjvoIlisc8LHugNsIWf0Perxzopw=; b=qvs1B/zQnfT+HT8wakIKuJzOAB5fT3HYBaP0tcMETF0LRocZDjChD+8cTi7MjVEOFOp2c2 cH8xPS5bzZA+akneOcqPwaKkyfSaErUk+rhyJIcHWrenn6kvATsYkYUuoi/TnxQeJiJHL6 Edk9J2IDJQFKVqUdhQR/jZeeE82fmUc= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1778516970; a=rsa-sha256; cv=none; b=tEDLS+EBAMnxZIObtOKdZ+uEFzVwqXg1SC7ruVoxGoOM6OZlJVtahVthqzwPlVBtSN3I9b rd2/vtg4TxSft8iXFmeH0v8A0+3KfkszCdFYw/Eu65x0wqb+pXTvKHPStoc0+HKYinab1y 1nOVoAr2FRiIivjWlXm9yP6GJDWYMsA= ARC-Authentication-Results: i=1; imf04.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=XqGjSiyt; spf=pass (imf04.hostedemail.com: domain of rppt@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=rppt@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by sea.source.kernel.org (Postfix) with ESMTP id 24B14439AD; Mon, 11 May 2026 16:29:29 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 042FDC2BCC9; Mon, 11 May 2026 16:29:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1778516969; bh=KCkW51Kg/Ggf8xybZkZ7vYzAzBA2UmxAIRfs2bz/Qt4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XqGjSiytDT42y1yAVDvNTmW2YAAgdiKzb58Ajp8vIXjCnbThu340p0umVIC0ruWgm JcBUEdh1VlHE62UJXj0phcuQOPEcD1D6kN0rlQRbgPjQy2EOqBWYtB4dkNYRtgeUA+ c27qb2daZprKwIKAdRW6V7kjMESb5MwE8YPfGsJ9KEt75uQwVA+g1I5UmYLzpr0mMo fXtsQUc8eZLHpavCxjX1ZgKJnuEhwhXzAF4ATEAmqjj/SlN+VEFl8TTL9UZnO3GBVM FF99+CioYBTmSiTm8o1PSBKzI7r6O8sgS2m3s1+6af8u27UA1wSqQ3zuVOOCHLbIhs 8VtEOCYPOWxTg== From: Mike Rapoport To: Andrew Morton , David Hildenbrand Cc: Baolin Wang , Barry Song , Dev Jain , Donet Tom , Jason Gunthorpe , John Hubbard , "Liam R. Howlett" , Lance Yang , Li Wang , Leon Romanovsky , Lorenzo Stoakes , Luiz Capitulino , Mark Brown , Michal Hocko , Mike Rapoport , Nico Pache , Peter Xu , Ryan Roberts , Sarthak Sharma , Shuah Khan , Suren Baghdasaryan , Vlastimil Babka , Zi Yan , linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH v4 06/55] selftests/mm: merge map_hugetlb into hugepage-mmap Date: Mon, 11 May 2026 19:27:50 +0300 Message-ID: <20260511162840.375890-7-rppt@kernel.org> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260511162840.375890-1-rppt@kernel.org> References: <20260511162840.375890-1-rppt@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Rspamd-Server: rspam12 X-Rspamd-Queue-Id: 0D72E4000D X-Stat-Signature: mr7yiwte8xua3qdwp4o7tqz893nsmesf X-Rspam-User: X-HE-Tag: 1778516969-737354 X-HE-Meta: U2FsdGVkX1+4vK3RhTQ1PHj5w7UCFAqFGp814g/5eHSkSTLQ8jQBrmRm7x9vbzBbfk+Yr8od34gR5En2g1kFcPffJ1zmEhN0SXeD4T/2JTuud5KrUGl8Zp8RQ1WssCcwltZCXfzqtlAlGWrpUkkYAuBWSDmdBw5JOxnH3tyCQO+i/oo6NUzjPfObd80qgbFf7wo1WfdXHurDlPd+ky+hQcm5q2/+wYdfPs3+TnbcwQw10epGHtjFHf2OAH331NqeRtbjUVO2OMq/7Dx/eYMP/t1+VAAiDgS/h2uqNhNX9mzd8n06tl+YhtswM4gxhhkrxNK9KR/8caioM9r1TtPz+4jOHBgI0lTdY0V3YXWdK6UQT9boHeVSRHxv+YEk9los5xIkKHDDMCSvK9xzlWod1F1VgzyiF/FH4P6DeWhgMadU3p4ZROebprQRk9VSlMniKESRK4SoVAUtI0/DAEJGrrdivqpPUQwFWhkymFoQMrtZp8KKTxyw0uWM9J636jO3Ge3rVa74chvZUW0ACypBNZ4STgmQ7Ji1G4mLMXxZPChShJ9OPd2Ek7AShPLAWW5KvrYdNEhzYPV6La7mVJ5P+sFncwJB6zozNAQOOC7LKhAcdl4nmaUZvV60mDbhkFGGPJV3LyS9rz0mnrZCzPIPENnSOd/ofgiLrj6nqqB3E3TGZxNdQSMD+bYsdd5SmOm40pH6vMTgXNUkWl5sMvExbJpToU2lDHU6yldRUrrz33Ex3MPGRrq51d7hMBv6dPGH5BzHNYjkC5LSQw8xsHoVxLP/LHGk/ZZLCfv8YDK390aJTLKdMAIFWwm9ht54+iSCvlfyh5g7Juo1U8BrzyYunfMSQk2wBACm5ruZ/OcnkXtZaJNSIaCOcK9ErtgDqI7BIQ8fruliNhq3+pIsKTIiMQcmZHrrQtYjQSfinRCo7QpUxkjBYjYMLqwYesdeZZocvzUyCiLOx3pi0voe6IC AbWAR5zq jJCN2ELwwVR/snKzo/TlS6K3IcIqHE8wHJymJ6M/WolnDHZVabvg/ty98RduoHDBL7A9/1Wyn36UXZEo5OkUscvjS3aNuMgp62sZCZxqCvm3rT/AUqekBbmkJVwjT4DuyXZGmK501iH9owN+goCPLLQprxqeEqUQ2+k76gqtxuwF/LxYxIACSRgZw0wIJFyVyclfDl3IcUyWgoXBmndDivbojm7k6AL7yTw+udB0wPU5b7l6iU7wrJkJpLynW6x6B70nxWdtHrx+tQBXERneTE05JBbMoFZSiD4KJsQk5NFUrUM5NnbSqpYKORXxq/3H+Y9vCKhj0vJaagBY= Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: From: "Mike Rapoport (Microsoft)" Both tests create a hugettlb mapping, fill it with data and verify the data, the only difference is that one uses file-backed memory and another one uses anonymous memory. Merge both tests into a single file. Reviewed-by: Luiz Capitulino Reviewed-by: Donet Tom Tested-by: Luiz Capitulino Signed-off-by: Mike Rapoport (Microsoft) --- Documentation/admin-guide/mm/hugetlbpage.rst | 7 +- tools/testing/selftests/mm/Makefile | 1 - tools/testing/selftests/mm/hugepage-mmap.c | 107 ++++++++++++++----- tools/testing/selftests/mm/map_hugetlb.c | 88 --------------- tools/testing/selftests/mm/run_vmtests.sh | 1 - 5 files changed, 84 insertions(+), 120 deletions(-) delete mode 100644 tools/testing/selftests/mm/map_hugetlb.c diff --git a/Documentation/admin-guide/mm/hugetlbpage.rst b/Documentation/admin-guide/mm/hugetlbpage.rst index 67a941903fd2..2dea8c636641 100644 --- a/Documentation/admin-guide/mm/hugetlbpage.rst +++ b/Documentation/admin-guide/mm/hugetlbpage.rst @@ -455,7 +455,7 @@ used to change the file attributes on hugetlbfs. Also, it is important to note that no such mount command is required if applications are going to use only shmat/shmget system calls or mmap with MAP_HUGETLB. For an example of how to use mmap with MAP_HUGETLB see -:ref:`map_hugetlb ` below. +:ref:`examples ` below. Users who wish to use hugetlb memory via shared memory segment should be members of a supplementary group and system admin needs to configure that gid @@ -473,10 +473,7 @@ a hugetlb page and the length is smaller than the hugepage size. Examples ======== -.. _map_hugetlb: - -``map_hugetlb`` - see tools/testing/selftests/mm/map_hugetlb.c +.. _examples: ``hugepage-shm`` see tools/testing/selftests/mm/hugepage-shm.c diff --git a/tools/testing/selftests/mm/Makefile b/tools/testing/selftests/mm/Makefile index cd24596cdd27..cbda989f6b6a 100644 --- a/tools/testing/selftests/mm/Makefile +++ b/tools/testing/selftests/mm/Makefile @@ -70,7 +70,6 @@ TEST_GEN_FILES += hugepage-vmemmap TEST_GEN_FILES += khugepaged TEST_GEN_FILES += madv_populate TEST_GEN_FILES += map_fixed_noreplace -TEST_GEN_FILES += map_hugetlb TEST_GEN_FILES += map_populate ifneq (,$(filter $(ARCH),arm64 riscv riscv64 x86 x86_64 loongarch32 loongarch64)) TEST_GEN_FILES += memfd_secret diff --git a/tools/testing/selftests/mm/hugepage-mmap.c b/tools/testing/selftests/mm/hugepage-mmap.c index d543419de040..66cf74b73dea 100644 --- a/tools/testing/selftests/mm/hugepage-mmap.c +++ b/tools/testing/selftests/mm/hugepage-mmap.c @@ -15,6 +15,8 @@ #include #include #include +#include +#include "vm_util.h" #include "kselftest.h" #define LENGTH (256UL*1024*1024) @@ -25,54 +27,109 @@ static void check_bytes(char *addr) ksft_print_msg("First hex is %x\n", *((unsigned int *)addr)); } -static void write_bytes(char *addr) +static void write_bytes(char *addr, size_t length) { unsigned long i; - for (i = 0; i < LENGTH; i++) + for (i = 0; i < length; i++) *(addr + i) = (char)i; } -static int read_bytes(char *addr) +static bool verify_bytes(char *addr, size_t length) { unsigned long i; check_bytes(addr); - for (i = 0; i < LENGTH; i++) + for (i = 0; i < length; i++) if (*(addr + i) != (char)i) { - ksft_print_msg("Error: Mismatch at %lu\n", i); - return 1; + ksft_print_msg("Error: Mismatch at %lu(%p)\n", i, addr); + return false; } - return 0; + + return true; } -int main(void) +static void test_mmap(size_t length, int mmap_flags, int fd, + const char *test_name) { + bool passed = true; void *addr; - int fd, ret; - ksft_print_header(); - ksft_set_plan(1); + addr = mmap(NULL, length, PROTECTION, mmap_flags, fd, 0); + if (addr == MAP_FAILED) + ksft_exit_fail_perror("mmap"); + + ksft_print_msg("Returned address is %p\n", addr); + check_bytes(addr); + write_bytes(addr, length); + if (!verify_bytes(addr, length)) + passed = false; + + /* munmap() length of MAP_HUGETLB memory must be hugepage aligned */ + if (munmap(addr, length)) + ksft_exit_fail_perror("munmap"); + + ksft_test_result(passed, "%s\n", test_name); +} + +static void test_anon_mmap(size_t length, int shift) +{ + const char *test_name = "hugetlb anonymous mmap"; + int mmap_flags = MAP_PRIVATE | MAP_ANONYMOUS | MAP_HUGETLB; + + if (shift) + mmap_flags |= (shift & MAP_HUGE_MASK) << MAP_HUGE_SHIFT; - fd = memfd_create("hugepage-mmap", MFD_HUGETLB); + test_mmap(length, mmap_flags, -1, test_name); +} + +static void test_file_mmap(size_t length, int shift) +{ + const char *test_name = "hugetlb file mmap"; + int mfd_flags = MFD_HUGETLB; + int fd; + + if (shift) + mfd_flags |= (shift & MFD_HUGE_MASK) << MFD_HUGE_SHIFT; + + fd = memfd_create("hugetlb-mmap", mfd_flags); if (fd < 0) - ksft_exit_fail_msg("memfd_create() failed: %s\n", strerror(errno)); + ksft_exit_fail_perror("memfd_create"); + + test_mmap(length, MAP_SHARED, fd, test_name); + close(fd); +} + +int main(int argc, char **argv) +{ + size_t hugepage_size; + size_t length = LENGTH; + int shift = 0; - addr = mmap(NULL, LENGTH, PROTECTION, MAP_SHARED, fd, 0); - if (addr == MAP_FAILED) { - close(fd); - ksft_exit_fail_msg("mmap(): %s\n", strerror(errno)); + ksft_print_header(); + ksft_set_plan(2); + + if (argc > 1) + length = atol(argv[1]) << 20; + if (argc > 2) + shift = atoi(argv[2]); + + if (shift) { + hugepage_size = (1UL << shift); + ksft_print_msg("%lu kB hugepages\n", 1UL << (shift - 10)); + } else { + hugepage_size = default_huge_page_size(); + ksft_print_msg("Default size hugepages (%lu kB)\n", hugepage_size >> 10); } - ksft_print_msg("Returned address is %p\n", addr); - check_bytes(addr); - write_bytes(addr); - ret = read_bytes(addr); + /* munmap will fail if the length is not page aligned */ + if (hugepage_size > length) + length = hugepage_size; - munmap(addr, LENGTH); - close(fd); + ksft_print_msg("Mapping %lu Mbytes\n", (unsigned long)length >> 20); - ksft_test_result(!ret, "Read same data\n"); + test_anon_mmap(length, shift); + test_file_mmap(length, shift); - ksft_exit(!ret); + ksft_finished(); } diff --git a/tools/testing/selftests/mm/map_hugetlb.c b/tools/testing/selftests/mm/map_hugetlb.c deleted file mode 100644 index aa409107611b..000000000000 --- a/tools/testing/selftests/mm/map_hugetlb.c +++ /dev/null @@ -1,88 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 -/* - * Example of using hugepage memory in a user application using the mmap - * system call with MAP_HUGETLB flag. Before running this program make - * sure the administrator has allocated enough default sized huge pages - * to cover the 256 MB allocation. - */ -#include -#include -#include -#include -#include -#include "vm_util.h" -#include "kselftest.h" - -#define LENGTH (256UL*1024*1024) -#define PROTECTION (PROT_READ | PROT_WRITE) - -static void check_bytes(char *addr) -{ - ksft_print_msg("First hex is %x\n", *((unsigned int *)addr)); -} - -static void write_bytes(char *addr, size_t length) -{ - unsigned long i; - - for (i = 0; i < length; i++) - *(addr + i) = (char)i; -} - -static void read_bytes(char *addr, size_t length) -{ - unsigned long i; - - check_bytes(addr); - for (i = 0; i < length; i++) - if (*(addr + i) != (char)i) - ksft_exit_fail_msg("Mismatch at %lu\n", i); - - ksft_test_result_pass("Read correct data\n"); -} - -int main(int argc, char **argv) -{ - void *addr; - size_t hugepage_size; - size_t length = LENGTH; - int flags = MAP_PRIVATE | MAP_ANONYMOUS | MAP_HUGETLB; - int shift = 0; - - hugepage_size = default_huge_page_size(); - /* munmap with fail if the length is not page aligned */ - if (hugepage_size > length) - length = hugepage_size; - - ksft_print_header(); - ksft_set_plan(1); - - if (argc > 1) - length = atol(argv[1]) << 20; - if (argc > 2) { - shift = atoi(argv[2]); - if (shift) - flags |= (shift & MAP_HUGE_MASK) << MAP_HUGE_SHIFT; - } - - if (shift) - ksft_print_msg("%u kB hugepages\n", 1 << (shift - 10)); - else - ksft_print_msg("Default size hugepages\n"); - ksft_print_msg("Mapping %lu Mbytes\n", (unsigned long)length >> 20); - - addr = mmap(NULL, length, PROTECTION, flags, -1, 0); - if (addr == MAP_FAILED) - ksft_exit_fail_msg("mmap: %s\n", strerror(errno)); - - ksft_print_msg("Returned address is %p\n", addr); - check_bytes(addr); - write_bytes(addr, length); - read_bytes(addr, length); - - /* munmap() length of MAP_HUGETLB memory must be hugepage aligned */ - if (munmap(addr, length)) - ksft_exit_fail_msg("munmap: %s\n", strerror(errno)); - - ksft_finished(); -} diff --git a/tools/testing/selftests/mm/run_vmtests.sh b/tools/testing/selftests/mm/run_vmtests.sh index e2dc9ac87bfc..61b450032af8 100755 --- a/tools/testing/selftests/mm/run_vmtests.sh +++ b/tools/testing/selftests/mm/run_vmtests.sh @@ -292,7 +292,6 @@ CATEGORY="hugetlb" run_test ./hugepage-shm echo "$shmmax" > /proc/sys/kernel/shmmax echo "$shmall" > /proc/sys/kernel/shmall -CATEGORY="hugetlb" run_test ./map_hugetlb CATEGORY="hugetlb" run_test ./hugepage-mremap CATEGORY="hugetlb" run_test ./hugepage-vmemmap CATEGORY="hugetlb" run_test ./hugetlb-madvise -- 2.53.0