From patchwork Tue Jan 7 14:25:53 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Ryan Roberts X-Patchwork-Id: 13929047 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]) by smtp.lore.kernel.org (Postfix) with ESMTP id 0A165E77198 for ; Tue, 7 Jan 2025 14:26:13 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 696B38D0005; Tue, 7 Jan 2025 09:26:13 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 61EE18D0001; Tue, 7 Jan 2025 09:26:13 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 4C2528D0005; Tue, 7 Jan 2025 09:26:13 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0010.hostedemail.com [216.40.44.10]) by kanga.kvack.org (Postfix) with ESMTP id 1C8A28D0001 for ; Tue, 7 Jan 2025 09:26:13 -0500 (EST) Received: from smtpin07.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay09.hostedemail.com (Postfix) with ESMTP id 5AC7C80B95 for ; Tue, 7 Jan 2025 14:26:08 +0000 (UTC) X-FDA: 82980880458.07.01BA536 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by imf10.hostedemail.com (Postfix) with ESMTP id CB607C0016 for ; Tue, 7 Jan 2025 14:26:06 +0000 (UTC) Authentication-Results: imf10.hostedemail.com; dkim=none; dmarc=pass (policy=none) header.from=arm.com; spf=pass (imf10.hostedemail.com: domain of ryan.roberts@arm.com designates 217.140.110.172 as permitted sender) smtp.mailfrom=ryan.roberts@arm.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1736259966; 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:references; bh=/Df7Q/Q78SyET0a81oXbpgHXa6Tvjfie0LP58EiCFLM=; b=qQ4gHB8tAtsMERMGbPaQaoSaUb34FeY+jcH0eS1f2gLt+ZOv91XYSsH2jHMat+mERb6jU+ 04BG6GZoe/qImy9M2ZC3vtY4wcTYfGvdVQkeXUF+CVAJKNgooDJ8k+W5G7OU+tz8veLeCq eR+nvenoexn1N1eAGuNs4QEWyNuHqs4= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1736259966; a=rsa-sha256; cv=none; b=ZqZPPpcClaiTw2T9rtZlDCLjeOh/aYgqYUWd/hntl2CDWZk3tf1f/zDw6GZd4FTDF1igYL mX5Gng4Lcpo1fufaPq+5Xoo1WX8jBKTLOTHXmMe5akP2p+9G0IZLogZavy/XXL50d1S6wI K6sD1Ttz1NhH+UomZQ4lOxzsp/+P9qY= ARC-Authentication-Results: i=1; imf10.hostedemail.com; dkim=none; dmarc=pass (policy=none) header.from=arm.com; spf=pass (imf10.hostedemail.com: domain of ryan.roberts@arm.com designates 217.140.110.172 as permitted sender) smtp.mailfrom=ryan.roberts@arm.com Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 0AC511424; Tue, 7 Jan 2025 06:26:34 -0800 (PST) Received: from e125769.cambridge.arm.com (e125769.cambridge.arm.com [10.1.196.27]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id C3B023F59E; Tue, 7 Jan 2025 06:26:04 -0800 (PST) From: Ryan Roberts To: Andrew Morton , Shuah Khan , David Hildenbrand Cc: Ryan Roberts , linux-mm@kvack.org, linux-kselftest@vger.kernel.org Subject: [PATCH v1] selftests/mm: Set allocated memory to non-zero content in cow test Date: Tue, 7 Jan 2025 14:25:53 +0000 Message-ID: <20250107142555.1870101-1-ryan.roberts@arm.com> X-Mailer: git-send-email 2.43.0 MIME-Version: 1.0 X-Stat-Signature: g6y611yq69iifu5f7a7y63tgusoskgzy X-Rspamd-Queue-Id: CB607C0016 X-Rspam-User: X-Rspamd-Server: rspam01 X-HE-Tag: 1736259966-415392 X-HE-Meta: U2FsdGVkX1+HUpklvRL7IYT6OlL8GlwjjXruaW6iTYzxHBUPHohrk0NwPMNvQBGH3Zvq2FzuwZGSdMENxZSjA1GYA7fycnRxO6SG3r6IYfnY8H0bEUFzsjHnzCCoHeZTGsennZEABJRibnPoAtwHYGRq89K80PTs70OaGhkf+jsqIpoobV7pKWuDjaLRLoLr8lr0eOFkSRwvibhk91GCdl/hE/HiSqLLvRgHJrRGaaZo9vW/o5Cu39HPJ5SC3Xv75SvnkBHUd6TlVgkSLXrsVyZLcGa6fGrscH3dQKbb0EK/fCwb5ujZUNEVWVwI8WkT6aEhx2S1pFdW8S0q7yLis+0n0di4l7fu1mVbfgDl+9iAcgMXMQ8gjgSc4giecSWJS4tagR5aK3j/iDOCzW/Em/Lx5i77fvhA8X/SyvIx3oMmDhJzYQ6llNHn6RHfilWjnlEs2Gk79m6jKS6TPml41geCUE0Rab6FUXAHaaby64+YrA8TJsIyYtI85XBlIxbNvWP0pMqoP3wWacDDf0ZBDBP1zahBT1gH5FSA1Ux2o2sMtFNEWbD7Ns7PgqXX03LNZxp37wHjQbkwnXoCqUMrQtFexS/75zBox8NFSUf5wPK1TleA52XZmEyDSgao3LDmnIKFy7XmMbPucVZBaiLm5LLxn+uAKBm8mykJdP19h0w1rZICXc1au3UWEw/rOJRrPWmC+hDgPckdiBg1rtPyTzp8tXEcKCf2BfKGA5QzdUmqbw1kviZqGLkRqeD19958nmQuYNhgtZAnJ8pH8BM0T9cy//1qL9qHojUtrddW7QMH+cPua2MM0jcCBDofON7GKKJJ0W55sDvfFQTigPhFe6MDEJvMY8me63EyBjPqQTwurj90Oo1nxqWaQFYip9mbBesOizU9LZUo2Qbv02AdtA8diNJB5HqyLJIUtJbzqYA8G2BIl6NS/vPwjcoyN2OD8U++eq+FEVUXsMjrcUp CdX7KenW dL1Tad/pzLkS1da3eDdmKf2r98gbC5XAv4pNlx8TuPsDp0HoXhNJ3aaKRS0soJfUi0RqJMwGiDnOvCUDjgTELI1gr5wmBy+FT/hvl5wltAdC18CGVCdDmR3eCtc24kxT/o/LWrOb+JPOQ6Ok03/YL0t4SYw== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: After commit b1f202060afe ("mm: remap unused subpages to shared zeropage when splitting isolated thp"), cow test cases involving swapping out THPs via madvise(MADV_PAGEOUT) started to be skipped due to the subsequent check via pagemap determining that the memory was not actually swapped out. Logs similar to this were emitted: ... # [RUN] Basic COW after fork() ... with swapped-out, PTE-mapped THP (16 kB) ok 2 # SKIP MADV_PAGEOUT did not work, is swap enabled? # [RUN] Basic COW after fork() ... with single PTE of swapped-out THP (16 kB) ok 3 # SKIP MADV_PAGEOUT did not work, is swap enabled? # [RUN] Basic COW after fork() ... with swapped-out, PTE-mapped THP (32 kB) ok 4 # SKIP MADV_PAGEOUT did not work, is swap enabled? ... The commit in question introduces the behaviour of scanning THPs and if their content is predominantly zero, it splits them and replaces the pages which are wholly zero with the zero page. These cow test cases were getting caught up in this. So let's avoid that by filling the contents of all allocated memory with a non-zero value. With this in place, the tests are passing again. Signed-off-by: Ryan Roberts Acked-by: David Hildenbrand --- Applies on top of mm-unstable (f349e79bfbf3) Thanks, Ryan tools/testing/selftests/mm/cow.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) -- 2.43.0 diff --git a/tools/testing/selftests/mm/cow.c b/tools/testing/selftests/mm/cow.c index 32c6ccc2a6be..1238e1c5aae1 100644 --- a/tools/testing/selftests/mm/cow.c +++ b/tools/testing/selftests/mm/cow.c @@ -758,7 +758,7 @@ static void do_run_with_base_page(test_fn fn, bool swapout) } /* Populate a base page. */ - memset(mem, 0, pagesize); + memset(mem, 1, pagesize); if (swapout) { madvise(mem, pagesize, MADV_PAGEOUT); @@ -824,12 +824,12 @@ static void do_run_with_thp(test_fn fn, enum thp_run thp_run, size_t thpsize) * Try to populate a THP. Touch the first sub-page and test if * we get the last sub-page populated automatically. */ - mem[0] = 0; + mem[0] = 1; if (!pagemap_is_populated(pagemap_fd, mem + thpsize - pagesize)) { ksft_test_result_skip("Did not get a THP populated\n"); goto munmap; } - memset(mem, 0, thpsize); + memset(mem, 1, thpsize); size = thpsize; switch (thp_run) { @@ -1012,7 +1012,7 @@ static void run_with_hugetlb(test_fn fn, const char *desc, size_t hugetlbsize) } /* Populate an huge page. */ - memset(mem, 0, hugetlbsize); + memset(mem, 1, hugetlbsize); /* * We need a total of two hugetlb pages to handle COW/unsharing