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]) by smtp.lore.kernel.org (Postfix) with ESMTP id 690A8C5AD49 for ; Tue, 3 Jun 2025 07:18:03 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 8554A6B0082; Tue, 3 Jun 2025 03:18:02 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 806B26B03C0; Tue, 3 Jun 2025 03:18:02 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 71C216B03C1; Tue, 3 Jun 2025 03:18:02 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0016.hostedemail.com [216.40.44.16]) by kanga.kvack.org (Postfix) with ESMTP id 57FDD6B0082 for ; Tue, 3 Jun 2025 03:17:59 -0400 (EDT) Received: from smtpin27.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id CA9D31D40EE for ; Tue, 3 Jun 2025 07:17:58 +0000 (UTC) X-FDA: 83513235036.27.4DB2B6C Received: from dggsgout11.his.huawei.com (dggsgout11.his.huawei.com [45.249.212.51]) by imf23.hostedemail.com (Postfix) with ESMTP id 1B2D2140007 for ; Tue, 3 Jun 2025 07:17:54 +0000 (UTC) Authentication-Results: imf23.hostedemail.com; dkim=none; dmarc=none; spf=pass (imf23.hostedemail.com: domain of pulehui@huaweicloud.com designates 45.249.212.51 as permitted sender) smtp.mailfrom=pulehui@huaweicloud.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1748935077; 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-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=NlI+/wat2knvsFSong7mKG+1IAY9zrI2YLxCqzPLgjs=; b=4ep5zYqKsJvgMcnF9WyxIX6eIsK85/5rPjbFOJ0de6fI1DBljeLCX091WRTiaoOPfRmEVs 16ToFMSyYBEYqM/nMkCQFPbDoGO48Djd6avQEkDG0+UyjPzp+IYBipHOGY+VMzRIxo3zD0 3LoMwDw0cr1W1dizPCH4EnBO4WTF4L8= ARC-Authentication-Results: i=1; imf23.hostedemail.com; dkim=none; dmarc=none; spf=pass (imf23.hostedemail.com: domain of pulehui@huaweicloud.com designates 45.249.212.51 as permitted sender) smtp.mailfrom=pulehui@huaweicloud.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1748935077; a=rsa-sha256; cv=none; b=LtxS2jqGvnVloYKKpyA5Jshlm26dUB1zynnDzQcOiunVAc2cR3jpmFOCXbmLTT9GhE04/L P9ypqBRIaWq8iZt6bi1ZcwjrvZkGRKcQKkqTW2qe05WKlZwuK6pN0hOrha45yWt8i0WhgN 7bqYY9XoBkBlTFJYax32obMS21dqvxk= Received: from mail.maildlp.com (unknown [172.19.93.142]) by dggsgout11.his.huawei.com (SkyGuard) with ESMTPS id 4bBMVk6nSkzYQvhx for ; Tue, 3 Jun 2025 15:17:50 +0800 (CST) Received: from mail02.huawei.com (unknown [10.116.40.128]) by mail.maildlp.com (Postfix) with ESMTP id 069A81A105D for ; Tue, 3 Jun 2025 15:17:50 +0800 (CST) Received: from [10.67.109.184] (unknown [10.67.109.184]) by APP4 (Coremail) with SMTP id gCh0CgD3pVqdoT5oHSlwOQ--.55901S2; Tue, 03 Jun 2025 15:17:49 +0800 (CST) Message-ID: <8ea3ec70-dbe7-424f-b07f-add7c1cb1852@huaweicloud.com> Date: Tue, 3 Jun 2025 15:17:49 +0800 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v1 3/4] selftests/mm: Extract read_sysfs and write_sysfs into vm_util Content-Language: en-US To: Lorenzo Stoakes , akpm@linux-foundation.org Cc: mhiramat@kernel.org, oleg@redhat.com, peterz@infradead.org, Liam.Howlett@oracle.com, vbabka@suse.cz, jannh@google.com, pfalcato@suse.de, linux-mm@kvack.org, linux-kernel@vger.kernel.org, stable@vger.kernel.org, pulehui@huawei.com References: <20250529155650.4017699-1-pulehui@huaweicloud.com> <20250529155650.4017699-4-pulehui@huaweicloud.com> From: Pu Lehui In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-CM-TRANSID:gCh0CgD3pVqdoT5oHSlwOQ--.55901S2 X-Coremail-Antispam: 1UD129KBjvJXoW3WFyxWrWUWr47Cr13ZFWfuFg_yoW3Grykp3 Z3Ja4jgw4xKry7Gr12qFn8WryFyrs7tayjy397J34Ivr1Utr9agrWIka4UGw1kurZagr4f AayfXFs3Cr1UJaDanT9S1TB71UUUUU7qnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUUv0b4IE77IF4wAFF20E14v26r4j6ryUM7CY07I20VC2zVCF04k2 6cxKx2IYs7xG6rWj6s0DM7CIcVAFz4kK6r1j6r18M28lY4IEw2IIxxk0rwA2F7IY1VAKz4 vEj48ve4kI8wA2z4x0Y4vE2Ix0cI8IcVAFwI0_tr0E3s1l84ACjcxK6xIIjxv20xvEc7Cj xVAFwI0_Gr1j6F4UJwA2z4x0Y4vEx4A2jsIE14v26rxl6s0DM28EF7xvwVC2z280aVCY1x 0267AKxVW0oVCq3wAS0I0E0xvYzxvE52x082IY62kv0487Mc02F40EFcxC0VAKzVAqx4xG 6I80ewAv7VC0I7IYx2IY67AKxVWUGVWUXwAv7VC2z280aVAFwI0_Jr0_Gr1lOx8S6xCaFV Cjc4AY6r1j6r4UM4x0Y48IcVAKI48JM4IIrI8v6xkF7I0E8cxan2IY04v7MxkF7I0En4kS 14v26r1q6r43MxAIw28IcxkI7VAKI48JMxC20s026xCaFVCjc4AY6r1j6r4UMI8I3I0E5I 8CrVAFwI0_Jr0_Jr4lx2IqxVCjr7xvwVAFwI0_JrI_JrWlx4CE17CEb7AF67AKxVWUtVW8 ZwCIc40Y0x0EwIxGrwCI42IY6xIIjxv20xvE14v26r1j6r1xMIIF0xvE2Ix0cI8IcVCY1x 0267AKxVW8JVWxJwCI42IY6xAIw20EY4v20xvaj40_Jr0_JF4lIxAIcVC2z280aVAFwI0_ Jr0_Gr1lIxAIcVC2z280aVCY1x0267AKxVW8JVW8JrUvcSsGvfC2KfnxnUUI43ZEXa7IUb mii3UUUUU== X-CM-SenderInfo: psxovxtxl6x35dzhxuhorxvhhfrp/ X-Rspamd-Queue-Id: 1B2D2140007 X-Stat-Signature: du5due9kxgaob6zw9yfc7hzjwkf1i4si X-Rspam-User: X-Rspamd-Server: rspam07 X-HE-Tag: 1748935074-887455 X-HE-Meta: U2FsdGVkX1/Dyaoi2eLOKsXwCi2Jy7jxtmT0snwB8f/NIPgL6/1f4BUqhyG785esp3cXuxKhv+ThGr3Dzk/v+XeTOcqFK0qLiaYa2vDYS52eevhRmpz40+C11UE9T88DHaCjK5XjoqQkwB9DiPeK05MBj8136byByfPqAdDXjAf2BtifZaHhl/OUMHPXhR9yhCgFxAmRWUXjmAZcthpFCpJ9g7vnoZ7cv3VcBB81N3m7oHE1M/T4SzXe0PzygW0CEqQBBvfCyxceBWptJxxNlwvftF+2lbY3za3tMcqWo8STh0ANbpkN1mcE5Rj55oNLh0y5AtPVcnxOFcK5tkrkTTBHeN7ccxyt6wmjMBa/4+YYE/tqDvL5L/7501fmzFhw4ze7lBvx/tlrF/sEb36tQ3P3h7Nrm67LLDpu2uTdilTha9qQ2N7vcLWch2+aJWu2VpSxc6IfAGgC4JGOUuLOM9XMss8zocLtVmCOm9QIiAzM6sxecDLJpJgjus6tFuRXR8WoAsj47r5nd7x6aRWeqyIserjVSo6jZvMdQ/mWqOIouc0/GiSJmqqg6CWT1IxmtX0igM+4J0UNshVG4ulG5RGGRvyJ0VbprBP7AV+9Q+x21jxhTHWk5dmjOKgwQ/Urmp2cgvOJ3TJB5oeAaORnf7a0Wh8P6tseUgcBKak78pJpKn7LsIwqUiQS7Y33j6/X55vr313i5jHIjoUQ+VSvZGLp4Pg/Aokd7MrdTqmqU95Y0OTdCNXxZeHWNFSheMfKPITrOWY6y1yP2kmuv2tIGItd+BZI4lSQx+xG+lrvTvr0HYap236gDDh7AMSyUsXh460GRewusG0sDdb2deUCacFf+9bXEE6fTbyjelUjBZgXS1EwRvTRgWTGqmcw2X418P+ML18Csy05FA828zV1UYsBEZqrKyIQuVFHnyeB8WmLqwgZw0FMJiStgpVv2qr3pHK6lUPMHIAbJ6f2Asj CSytOa1f 1Pbxm3N4ZMTf+VnfjqwFMTpH9AQOblCjHyoMu5IQFMsFORLOuJM44X+81LvODkOoo9U/+l7QUls1NMSirakR+IDNkCxyU7GPC2Y74H1ZjTHTnOlJwP4JIWNB8uw2my5Vid5M04dnRdCYXLX3AkY+Xca6buqNejBlQDkiuTq0wn26TDlk9q9eleX7E0t8726ENSIdkC3IuWwe/ujmxz6ygwEYZhWPsBYzc80b9ThgjGCoIwtpAn9g9c2sUFGCJPJQDJvWp 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: On 2025/5/30 19:48, Lorenzo Stoakes wrote: > On Thu, May 29, 2025 at 03:56:49PM +0000, Pu Lehui wrote: >> From: Pu Lehui >> >> Extract read_sysfs and write_sysfs into vm_util. Meanwhile, rename >> the function in thuge-gen that has the same name as read_sysfs. > > Nice! > >> >> Signed-off-by: Pu Lehui > > Reviewed-by: Lorenzo Stoakes > >> --- >> tools/testing/selftests/mm/ksm_tests.c | 32 ++-------------------- >> tools/testing/selftests/mm/thuge-gen.c | 6 ++-- >> tools/testing/selftests/mm/vm_util.c | 38 ++++++++++++++++++++++++++ >> tools/testing/selftests/mm/vm_util.h | 2 ++ >> 4 files changed, 45 insertions(+), 33 deletions(-) >> >> diff --git a/tools/testing/selftests/mm/ksm_tests.c b/tools/testing/selftests/mm/ksm_tests.c >> index dcdd5bb20f3d..e80deac1436b 100644 >> --- a/tools/testing/selftests/mm/ksm_tests.c >> +++ b/tools/testing/selftests/mm/ksm_tests.c >> @@ -58,40 +58,12 @@ int debug; >> >> static int ksm_write_sysfs(const char *file_path, unsigned long val) >> { >> - FILE *f = fopen(file_path, "w"); >> - >> - if (!f) { >> - fprintf(stderr, "f %s\n", file_path); >> - perror("fopen"); >> - return 1; >> - } >> - if (fprintf(f, "%lu", val) < 0) { >> - perror("fprintf"); >> - fclose(f); >> - return 1; >> - } >> - fclose(f); >> - >> - return 0; >> + return write_sysfs(file_path, val); >> } >> >> static int ksm_read_sysfs(const char *file_path, unsigned long *val) >> { >> - FILE *f = fopen(file_path, "r"); >> - >> - if (!f) { >> - fprintf(stderr, "f %s\n", file_path); >> - perror("fopen"); >> - return 1; >> - } >> - if (fscanf(f, "%lu", val) != 1) { >> - perror("fscanf"); >> - fclose(f); >> - return 1; >> - } >> - fclose(f); >> - >> - return 0; >> + return read_sysfs(file_path, val); >> } >> >> static void ksm_print_sysfs(void) >> diff --git a/tools/testing/selftests/mm/thuge-gen.c b/tools/testing/selftests/mm/thuge-gen.c >> index a41bc1234b37..95b6f043a3cb 100644 >> --- a/tools/testing/selftests/mm/thuge-gen.c >> +++ b/tools/testing/selftests/mm/thuge-gen.c >> @@ -77,7 +77,7 @@ void show(unsigned long ps) >> system(buf); >> } >> >> -unsigned long read_sysfs(int warn, char *fmt, ...) >> +unsigned long thuge_read_sysfs(int warn, char *fmt, ...) >> { > > I wonder if we could update these to use the newly shared functions? > > Not a big deal though, perhaps a bit out of scope here, more of a nice-to-have. Hi Lorenzo, Andrew, Yep, we can do it more. But, actually, I am not sure about the merge process of mm module. Do I need to resend the whole series or just the diff below? From 13ecf9d66a0068d520be955e3ca8d9c0dc9d8393 Mon Sep 17 00:00:00 2001 From: Pu Lehui Date: Tue, 3 Jun 2025 06:50:43 +0000 Subject: [PATCH] selftests/mm: Use generic read_sysfs in thuge-gen test Use generic read_sysfs in thuge-gen test. Signed-off-by: Pu Lehui --- tools/testing/selftests/mm/thuge-gen.c | 37 +++++++------------------- 1 file changed, 9 insertions(+), 28 deletions(-) diff --git a/tools/testing/selftests/mm/thuge-gen.c b/tools/testing/selftests/mm/thuge-gen.c index 95b6f043a3cb..5a32ed0ba26c 100644 --- a/tools/testing/selftests/mm/thuge-gen.c +++ b/tools/testing/selftests/mm/thuge-gen.c @@ -77,40 +77,19 @@ void show(unsigned long ps) system(buf); } -unsigned long thuge_read_sysfs(int warn, char *fmt, ...) +unsigned long read_free(unsigned long ps) { - char *line = NULL; - size_t linelen = 0; - char buf[100]; - FILE *f; - va_list ap; unsigned long val = 0; + char buf[100]; - va_start(ap, fmt); - vsnprintf(buf, sizeof buf, fmt, ap); - va_end(ap); + snprintf(buf, sizeof buf, + "/sys/kernel/mm/hugepages/hugepages-%lukB/free_hugepages", + ps >> 10); + read_sysfs(buf, &val); - f = fopen(buf, "r"); - if (!f) { - if (warn) - ksft_print_msg("missing %s\n", buf); - return 0; - } - if (getline(&line, &linelen, f) > 0) { - sscanf(line, "%lu", &val); - } - fclose(f); - free(line); return val; } -unsigned long read_free(unsigned long ps) -{ - return thuge_read_sysfs(ps != getpagesize(), - "/sys/kernel/mm/hugepages/hugepages-%lukB/free_hugepages", - ps >> 10); -} - void test_mmap(unsigned long size, unsigned flags) { char *map; @@ -173,6 +152,7 @@ void test_shmget(unsigned long size, unsigned flags) void find_pagesizes(void) { unsigned long largest = getpagesize(); + unsigned long shmmax_val = 0; int i; glob_t g; @@ -195,7 +175,8 @@ void find_pagesizes(void) } globfree(&g); - if (thuge_read_sysfs(0, "/proc/sys/kernel/shmmax") < NUM_PAGES * largest) + read_sysfs("/proc/sys/kernel/shmmax", &shmmax_val); + if (shmmax_val < NUM_PAGES * largest) ksft_exit_fail_msg("Please do echo %lu > /proc/sys/kernel/shmmax", largest * NUM_PAGES); -- 2.34.1 > >> char *line = NULL; >> size_t linelen = 0; >> @@ -106,7 +106,7 @@ unsigned long read_sysfs(int warn, char *fmt, ...) >> >> unsigned long read_free(unsigned long ps) >> { >> - return read_sysfs(ps != getpagesize(), >> + return thuge_read_sysfs(ps != getpagesize(), >> "/sys/kernel/mm/hugepages/hugepages-%lukB/free_hugepages", >> ps >> 10); >> } >> @@ -195,7 +195,7 @@ void find_pagesizes(void) >> } >> globfree(&g); >> >> - if (read_sysfs(0, "/proc/sys/kernel/shmmax") < NUM_PAGES * largest) >> + if (thuge_read_sysfs(0, "/proc/sys/kernel/shmmax") < NUM_PAGES * largest) >> ksft_exit_fail_msg("Please do echo %lu > /proc/sys/kernel/shmmax", >> largest * NUM_PAGES); >> >> diff --git a/tools/testing/selftests/mm/vm_util.c b/tools/testing/selftests/mm/vm_util.c >> index 1357e2d6a7b6..d899c272e0ee 100644 >> --- a/tools/testing/selftests/mm/vm_util.c >> +++ b/tools/testing/selftests/mm/vm_util.c >> @@ -486,3 +486,41 @@ int close_procmap(struct procmap_fd *procmap) >> { >> return close(procmap->fd); >> } >> + >> +int write_sysfs(const char *file_path, unsigned long val) >> +{ >> + FILE *f = fopen(file_path, "w"); >> + >> + if (!f) { >> + fprintf(stderr, "f %s\n", file_path); >> + perror("fopen"); >> + return 1; >> + } >> + if (fprintf(f, "%lu", val) < 0) { >> + perror("fprintf"); >> + fclose(f); >> + return 1; >> + } >> + fclose(f); >> + >> + return 0; >> +} >> + >> +int read_sysfs(const char *file_path, unsigned long *val) >> +{ >> + FILE *f = fopen(file_path, "r"); >> + >> + if (!f) { >> + fprintf(stderr, "f %s\n", file_path); >> + perror("fopen"); >> + return 1; >> + } >> + if (fscanf(f, "%lu", val) != 1) { >> + perror("fscanf"); >> + fclose(f); >> + return 1; >> + } >> + fclose(f); >> + >> + return 0; >> +} >> diff --git a/tools/testing/selftests/mm/vm_util.h b/tools/testing/selftests/mm/vm_util.h >> index 9211ba640d9c..f84c7c4680ea 100644 >> --- a/tools/testing/selftests/mm/vm_util.h >> +++ b/tools/testing/selftests/mm/vm_util.h >> @@ -87,6 +87,8 @@ int open_procmap(pid_t pid, struct procmap_fd *procmap_out); >> int query_procmap(struct procmap_fd *procmap); >> bool find_vma_procmap(struct procmap_fd *procmap, void *address); >> int close_procmap(struct procmap_fd *procmap); >> +int write_sysfs(const char *file_path, unsigned long val); >> +int read_sysfs(const char *file_path, unsigned long *val); >> >> static inline int open_self_procmap(struct procmap_fd *procmap_out) >> { >> -- >> 2.34.1 >>