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 83E23C7EE2E for ; Sun, 28 May 2023 17:54:22 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id A66A7900003; Sun, 28 May 2023 13:54:21 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id A17E5900002; Sun, 28 May 2023 13:54:21 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 8DE97900003; Sun, 28 May 2023 13:54:21 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 7B6BE900002 for ; Sun, 28 May 2023 13:54:21 -0400 (EDT) Received: from smtpin28.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id 3F7301602BA for ; Sun, 28 May 2023 17:54:21 +0000 (UTC) X-FDA: 80840413122.28.B1A2CC6 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by imf09.hostedemail.com (Postfix) with ESMTP id 739C914000D for ; Sun, 28 May 2023 17:54:19 +0000 (UTC) Authentication-Results: imf09.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=F4rYogy8; dmarc=pass (policy=none) header.from=kernel.org; spf=pass (imf09.hostedemail.com: domain of rppt@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=rppt@kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1685296459; 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:dkim-signature; bh=NTpsaNEzOiR/UHPizM/yIbeytpq3Ui4MTOi/y3C/kv8=; b=KcSCy+Jxwty57+FCSeOkNaGjMXgzh4WaXWwVnfJK9n0K/gd97l0SeSaPqOmnA1nP9Gzmqs N49QGGklP1NWIkIknZ8yCpMsN1FF1i30dxnQzOLEKJMl1xayQ0BqYmN6MRycy8Bc0kKkCf GIkImUxLHrd9q6AQcweDtvm6d8p5sMk= ARC-Authentication-Results: i=1; imf09.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=F4rYogy8; dmarc=pass (policy=none) header.from=kernel.org; spf=pass (imf09.hostedemail.com: domain of rppt@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=rppt@kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1685296459; a=rsa-sha256; cv=none; b=FuvQZ0RgcN+1iBR1+h4zeTeyq7gH8YyGY9kgSHHzjelsd/zOhguXLlbS3YYvxwKBbAOTV6 hOqqdUY2Jsn9GSD5D0DjB9iZTIosD4AanWWjnc0BAxMRokKXSq+0s+TIw8Ex7WXq0tx+Fe tZ6gi1RihTpuwuCqTzXLeZFpRnxX0c4= Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 4B53960BC1; Sun, 28 May 2023 17:54:18 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 35F86C433D2; Sun, 28 May 2023 17:54:14 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1685296457; bh=y1CuNarFZv5dQKVpLVgD0nZGqP2nsjhVEFaOMwLaaR4=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=F4rYogy8UyUcFaY+DQJbqKwZyYhvKqwAzpQ6F5ULjjjIapy36KwE21po57JodnAv7 nc2mXQR8mKgz5Uca5BcNV16sWEmNfH62S3w4LMX3fDphIywfa3etmi8wqogxDU8WVt nKWRdFXZZKMn8Cmi+amyIsEUA6XgQ+lQTMucgdMiu0zApXfB/XC8yjVXp7FxhZngvW RLKwGoVCwU+NcWO8GXeN51wfL7odNZ3gfDKQL6l4y6hjKPfK9EoSH8QfM+Jkl73bbj YEOc9pUzHzUdEjTJ2Jjs/fPzqTN6sIydmxDtbX/y9oed8TUSuoDCRLQdpJhz+RepOL h/hLORysaXU8w== Date: Sun, 28 May 2023 20:53:54 +0300 From: Mike Rapoport To: Yuwei Guan Cc: akpm@linux-foundation.org, tsahu@linux.ibm.com, anshuman.khandual@arm.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org, wangkefeng.wang@huawei.com Subject: Re: [PATCH v4] memblock: Add flags and nid info in memblock debugfs Message-ID: <20230528175354.GJ4967@kernel.org> References: <20230519105321.333-1-ssawgyw@gmail.com> <20230527103722.GG4967@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Rspamd-Queue-Id: 739C914000D X-Rspam-User: X-Rspamd-Server: rspam04 X-Stat-Signature: bmad1ewnhdn4pgr5tzdb11jzfeddfuki X-HE-Tag: 1685296459-928978 X-HE-Meta: U2FsdGVkX18KGG8hmUjucqH3fwvwPbv1RB+l76JEGONFmXEqLwCuTBAzHpkPNMuRcUFpBL9l90KqhtoZIBYVBmCcCohlV38nDuVZbkpP+ui4ED/XCtbbHKV8ntIrBe3KLvUz2f9mbdb7/5vLT8YcUtb6m6Gt8ufw/BKtfA4LcWQu0xF0XzpWw5gem0SGNCKLKsd+hAhQ7d1NU7Wf8Nz44w4/Vvqn0R6ZxHC4zqJOvPurD2hNxyCDlnxLER/j5tHp4/FbMRz8+HCz6hbIiTDFYQPXg9oi17+rBtgRMI/pyL50BC5f2oJJXBANyBgD9ehR1NC1eBob5l0pJbK9ITOzpzGkpQkk9JuZiOJ1hyvOw4tXpFsOIOfvaDpFqeycodC0Blwnocyt/19r+KpbMUZm7yTrxvWZtJ68MyA77U2G0FdywduAENEXrpLl2tuh3Hq4/acPnw+cj9JWUZIODLbyRKCmTYWw+VD+4FOVbfl6hA4m2uiZyvuvnFFjBS7buKKogXo9eDPJBOJDB/dv8EricTE+oUNBmOcKlw2LLlVNXa8Zja0pQOuNcdJL197/qgWCSPnm17zIuZirhf9ISY69F8qyznV9Z64p0a817ufLS+0uT6bVoDc0kmYraBuRKmB7SERAq1QUJrU/emkwYT6UNcHlgt9Rp0wbN3CroBYTZDUNu6zRvPW2hRH+M79lSrXOvIAwvkJ70b4vAA7qQANobcSjLgkeHa1t2F8Gr8qxM5XvGoLYjRsAkWbC2ZV0SPa3Rq8Z9i1Aa49z3Muuv+ukljgs84t5DekYc+2CdwsniKU+wSDYRly2O2pDquq99jfPNRkw2gg9OCcAtEcdYWpr7Mc6jlERQAMYkKnBwPU7Qrq8Qkh/Wa0JM/KMYskJQJ4JJPgbPAm/8Km1/es0TnmR0sG+czmxMXRfgLK6J2pEcYM2kDYFQlrehZY/msa1FGUcmi5baYbFEs9AmTstl6T RwALjDwJ XviEqkdZ+FhcOae//mZCwyllOV2tSHs1sBloSz75o24E3rrK0FOtftLVpXxv/R3rJlI2IhpBGyiitep50n5DB1x4XMuwGVjvpBZFdmFdgnPAKn+qXDLbGX/DfVmExUIbHVMooAJCLej0blxRTNOsiummA5HgtkMza7dO32Qjf73AFIrYHfWmbuGNtkg9q0qoDQWvTWAd1wa+ZFKFFUVWY1yKrbnxhB4ueGPU5QKrKKMpqX46ZAGE5TOHSsrstfiDkJI8n85EHWJz2GKpWP7rrLR0VISPbryuTUvXW9NqwDETXXP0e0lPkzjmoO+awKCl5usGxnJ1Nu5z4JBDt+J9NnclFO6qDRfWIQfcTUx73hmKaCi8KwIAVhlhN0tRcYIwxCj38gDJCIqI1FHI= 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: On Sun, May 28, 2023 at 10:38:03PM +0800, Yuwei Guan wrote: > Mike Rapoport 于2023年5月27日周六 18:37写道: > > > > Hi Yuwei, > > > > On Fri, May 19, 2023 at 06:53:21PM +0800, Yuwei Guan wrote: > > > > > Signed-off-by: Yuwei Guan > > > --- > > > v4: > > > - show string value for each memblock flag > > > --- > > > mm/memblock.c | 24 ++++++++++++++++++++++-- > > > 1 file changed, 22 insertions(+), 2 deletions(-) > > > > > > diff --git a/mm/memblock.c b/mm/memblock.c > > > index 511d4783dcf1..10d0ddbeebc1 100644 > > > --- a/mm/memblock.c > > > +++ b/mm/memblock.c > > > @@ -2136,12 +2136,19 @@ void __init memblock_free_all(void) > > > } > > > > > > #if defined(CONFIG_DEBUG_FS) && defined(CONFIG_ARCH_KEEP_MEMBLOCK) > > > +static const char * const flagname[] = { > > > + [ilog2(MEMBLOCK_HOTPLUG)] = "HOTPLUG", > > > + [ilog2(MEMBLOCK_MIRROR)] = "MIRROR", > > > + [ilog2(MEMBLOCK_NOMAP)] = "NOMAP", > > > + [ilog2(MEMBLOCK_DRIVER_MANAGED)] = "DRV_MNG", > > > +}; > > > > > > static int memblock_debug_show(struct seq_file *m, void *private) > > > { > > > struct memblock_type *type = m->private; > > > struct memblock_region *reg; > > > - int i; > > > + int i, j; > > > + unsigned int count = ARRAY_SIZE(flagname); > > > phys_addr_t end; > > > > > > for (i = 0; i < type->cnt; i++) { > > > @@ -2149,7 +2156,20 @@ static int memblock_debug_show(struct seq_file *m, void *private) > > > end = reg->base + reg->size - 1; > > > > > > seq_printf(m, "%4d: ", i); > > > - seq_printf(m, "%pa..%pa\n", ®->base, &end); > > > + seq_printf(m, "%pa..%pa ", ®->base, &end); > > > + seq_printf(m, "%4d ", memblock_get_region_node(reg)); > > > > As Kefeng mentioned, the node id for reserved regions will be wrong, so > > this needs to be updated so that when reg->nid == MAX_NUMNODES we'll print > > e.g. 'x'. > Hi Mike, > > How about print 'x' when reg->nid == MAX_NUMNODES, base on this patch, > https://lore.kernel.org/linux-mm/44ce007d-8049-1cc9-7e2e-4ccb51a2867d@huawei.com/T/#m6d214d4ea8912b64f5efc9c3f51ae71aa057d1f1 This is fine, can you please send a formal patch? > diff --git a/mm/memblock.c b/mm/memblock.c > index c5c80d9bcea3..3d449aaba052 100644 > --- a/mm/memblock.c > +++ b/mm/memblock.c > @@ -2169,17 +2169,21 @@ static int memblock_debug_show(struct seq_file > *m, void *private) > { > struct memblock_type *type = m->private; > struct memblock_region *reg; > - int i, j; > + int i, j, nid; > unsigned int count = ARRAY_SIZE(flagname); > phys_addr_t end; > > for (i = 0; i < type->cnt; i++) { > reg = &type->regions[i]; > end = reg->base + reg->size - 1; > + nid = memblock_get_region_node(reg); > > seq_printf(m, "%4d: ", i); > seq_printf(m, "%pa..%pa ", ®->base, &end); > - seq_printf(m, "%4d ", memblock_get_region_node(reg)); > + if (nid != MAX_NUMNODES) > + seq_printf(m, "%4d ", nid); > + else > + seq_printf(m, "%4c ", 'x'); > if (reg->flags) { > for (j = 0; j < count; j++) { > if (reg->flags & (1U << j)) { > > > > > > + if (reg->flags) { > > > + for (j = 0; j < count; j++) { > > > + if (reg->flags & (1U << j)) { > > > + seq_printf(m, "%s\n", flagname[j]); > > > + break; > > > + } > > > + } > > > + if (j == count) > > > + seq_printf(m, "%s\n", "UNKNOWN"); > > > + } else { > > > + seq_printf(m, "%s\n", "NONE"); > > > + } > > > } > > > return 0; > > > } > > > -- > > > 2.34.1 > > > > > > > -- > > Sincerely yours, > > Mike. -- Sincerely yours, Mike.