{"id":2219935,"url":"http://patchwork.ozlabs.org/api/1.2/patches/2219935/?format=json","web_url":"http://patchwork.ozlabs.org/project/linuxppc-dev/patch/20260405125240.2558577-11-songmuchun@bytedance.com/","project":{"id":2,"url":"http://patchwork.ozlabs.org/api/1.2/projects/2/?format=json","name":"Linux PPC development","link_name":"linuxppc-dev","list_id":"linuxppc-dev.lists.ozlabs.org","list_email":"linuxppc-dev@lists.ozlabs.org","web_url":"https://github.com/linuxppc/wiki/wiki","scm_url":"https://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux.git","webscm_url":"https://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux.git/","list_archive_url":"https://lore.kernel.org/linuxppc-dev/","list_archive_url_format":"https://lore.kernel.org/linuxppc-dev/{}/","commit_url_format":"https://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux.git/commit/?id={}"},"msgid":"<20260405125240.2558577-11-songmuchun@bytedance.com>","list_archive_url":"https://lore.kernel.org/linuxppc-dev/20260405125240.2558577-11-songmuchun@bytedance.com/","date":"2026-04-05T12:52:01","name":"[10/49] mm: move subsection_map_init() into sparse_init()","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"732a0fa772b4f868d7089b1a481fe5d8edc2abab","submitter":{"id":78930,"url":"http://patchwork.ozlabs.org/api/1.2/people/78930/?format=json","name":"Muchun Song","email":"songmuchun@bytedance.com"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/linuxppc-dev/patch/20260405125240.2558577-11-songmuchun@bytedance.com/mbox/","series":[{"id":498783,"url":"http://patchwork.ozlabs.org/api/1.2/series/498783/?format=json","web_url":"http://patchwork.ozlabs.org/project/linuxppc-dev/list/?series=498783","date":"2026-04-05T12:51:51","name":"mm: Generalize vmemmap optimization for DAX and HugeTLB","version":1,"mbox":"http://patchwork.ozlabs.org/series/498783/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2219935/comments/","check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2219935/checks/","tags":{},"related":[],"headers":{"Return-Path":"\n <linuxppc-dev+bounces-19340-incoming=patchwork.ozlabs.org@lists.ozlabs.org>","X-Original-To":["incoming@patchwork.ozlabs.org","linuxppc-dev@lists.ozlabs.org"],"Delivered-To":"patchwork-incoming@legolas.ozlabs.org","Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=bytedance.com header.i=@bytedance.com\n header.a=rsa-sha256 header.s=google header.b=b91g43zH;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=lists.ozlabs.org\n (client-ip=2404:9400:21b9:f100::1; helo=lists.ozlabs.org;\n envelope-from=linuxppc-dev+bounces-19340-incoming=patchwork.ozlabs.org@lists.ozlabs.org;\n receiver=patchwork.ozlabs.org)","lists.ozlabs.org;\n arc=none smtp.remote-ip=\"2607:f8b0:4864:20::102d\"","lists.ozlabs.org;\n dmarc=pass (p=quarantine dis=none) header.from=bytedance.com","lists.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=bytedance.com header.i=@bytedance.com\n header.a=rsa-sha256 header.s=google header.b=b91g43zH;\n\tdkim-atps=neutral","lists.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=bytedance.com\n (client-ip=2607:f8b0:4864:20::102d; helo=mail-pj1-x102d.google.com;\n envelope-from=songmuchun@bytedance.com; receiver=lists.ozlabs.org)"],"Received":["from lists.ozlabs.org (lists.ozlabs.org\n [IPv6:2404:9400:21b9:f100::1])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4fpXV45G05z1yCs\n\tfor <incoming@patchwork.ozlabs.org>; Sun, 05 Apr 2026 22:54:36 +1000 (AEST)","from boromir.ozlabs.org (localhost [127.0.0.1])\n\tby lists.ozlabs.org (Postfix) with ESMTP id 4fpXTy1tr2z2yqP;\n\tSun, 05 Apr 2026 22:54:30 +1000 (AEST)","from mail-pj1-x102d.google.com (mail-pj1-x102d.google.com\n [IPv6:2607:f8b0:4864:20::102d])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519 server-signature RSA-PSS (2048 bits) server-digest\n SHA256)\n\t(No client certificate requested)\n\tby lists.ozlabs.org (Postfix) with ESMTPS id 4fpXTx3cMXz2ypw\n\tfor <linuxppc-dev@lists.ozlabs.org>; Sun, 05 Apr 2026 22:54:29 +1000 (AEST)","by mail-pj1-x102d.google.com with SMTP id\n 98e67ed59e1d1-354bc7c2c46so1787299a91.0\n        for <linuxppc-dev@lists.ozlabs.org>;\n Sun, 05 Apr 2026 05:54:29 -0700 (PDT)","from n232-176-004.byted.org ([36.110.163.97])\n        by smtp.gmail.com with ESMTPSA id\n 98e67ed59e1d1-35de66b4808sm3748505a91.2.2026.04.05.05.54.20\n        (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n        Sun, 05 Apr 2026 05:54:26 -0700 (PDT)"],"ARC-Seal":"i=1; a=rsa-sha256; d=lists.ozlabs.org; s=201707; t=1775393670;\n\tcv=none;\n b=W3K/ZYxJNoL3HXX1a3BwNa328VeASUbJ4OXXno/a7o1Au0yK+d17XfhbEcqHuBj+Gl4s69dBLmyKk7My4yPHsij944azkFR6sf987uSjfu0QlBMjn0MUhSpPCyi3yA9NYC301bvqnzsZPvs7X9dQOoWFgl8TpD37/Q9qn2ptV9334K7W+x9UUuJT/Eo5hXUi0X2GmkHm/R0+66cHtc4ftICwNVOGuDzudkcNMNck0r31lExKS7mxRIXCEdpbvICmYojEvUioAIlEaOGOb1PrUU+8BuHQml/N/YxZSl7z8Piq0COvNQykxyrqaAvSQc/i9saRcnghSg/BdZHmC9sP2g==","ARC-Message-Signature":"i=1; a=rsa-sha256; d=lists.ozlabs.org; s=201707;\n\tt=1775393670; c=relaxed/relaxed;\n\tbh=uQZVpg6xJPTStuz2eFGC89hf7AN4wP07MvFFryn7lXk=;\n\th=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References:\n\t MIME-Version;\n b=RFVAsCPleIo5C3pMbcWLQlBT8mYalDZxgwIt6hq7pPjpV1t5rqu6vu6fClvl0j9NjRfqfLQoOtrZf/lREfXFeM+PO2UwY6f94ZPtmP7drDSlE67+QqKPUrTWFwquzwLF+CgBFcSr67nx4rP7uFrfIpn/lKN3tA0rlmb05zMicV8o4LyVOEE9dGpkPdbZSC6GNKNalbxOtdxq9dejtl+BJIWNscNIoeMi47qG9ekJ1zeFfPqgpXNksyd+0mWvvBOmHPvF8zcWQmqlE49kNQ8yhZc/W+unZ6muqUbzDXtTVoJUxUpXxOXWkH4T7R1p0uicU3L56meZtICdRF8gnDzRSA==","ARC-Authentication-Results":"i=1; lists.ozlabs.org;\n dmarc=pass (p=quarantine dis=none) header.from=bytedance.com;\n dkim=pass (2048-bit key;\n unprotected) header.d=bytedance.com header.i=@bytedance.com\n header.a=rsa-sha256 header.s=google header.b=b91g43zH; dkim-atps=neutral;\n spf=pass (client-ip=2607:f8b0:4864:20::102d; helo=mail-pj1-x102d.google.com;\n envelope-from=songmuchun@bytedance.com;\n receiver=lists.ozlabs.org) smtp.mailfrom=bytedance.com","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed;\n        d=bytedance.com; s=google; t=1775393667; x=1775998467;\n darn=lists.ozlabs.org;\n        h=content-transfer-encoding:mime-version:references:in-reply-to\n         :message-id:date:subject:cc:to:from:from:to:cc:subject:date\n         :message-id:reply-to;\n        bh=uQZVpg6xJPTStuz2eFGC89hf7AN4wP07MvFFryn7lXk=;\n        b=b91g43zH3kc850iYqEJe6RIi85tr6LJghseLi7yBsqUy28joVDbLiDu4sEOHUEEtQx\n         kGwgWgvRKKRzApyEhHK1KVM4KUtvjR/c7Lh21PySFT14URAUz3gacoDnosFege4yCAco\n         02ktJctM7iALrdJtqeC7joKtycQPu1n20axKxpeW3FyY5dcLLBhyQx+LN1d6PwttvbSH\n         SLgsPdYN47xIArqAwrLDQLOJUzpo7sgsjv2Iz0/vW9b3V2w3IiSCPTLtssQ9XzW+9Pcr\n         Nt/Lp4OtkzEVgkM/R/SrkRpuvdNGWExW9vJFk+LFchBrCCBF3CRfhb+yIk7+U00DuYNT\n         sr7w==","X-Google-DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed;\n        d=1e100.net; s=20251104; t=1775393667; x=1775998467;\n        h=content-transfer-encoding:mime-version:references:in-reply-to\n         :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from\n         :to:cc:subject:date:message-id:reply-to;\n        bh=uQZVpg6xJPTStuz2eFGC89hf7AN4wP07MvFFryn7lXk=;\n        b=iw0Vt3g8pZLRtWFwEXZlTLE/hO5DmM0jxfkUF/SlN+0qiqRjWmtVrb059QRTtIt6bq\n         Y5loYgsO0cnSuTuTfXLBIqrfKucijBUq+0dyzboL7kBhh8rTGhN21UyPmijxv+jB6V8b\n         KFEqzzdWYTW1BvDa8891dy1IjbA+QNLNoyM72wbMBuPxOb3AqYrh/RHgi0vBh6M5W1n7\n         7NRF2+24cxC2uQ+MQCwl7KYUXqWTabRqKovRjbd/6fED1ASp3vkHzVWFFiK2eYkr37Ho\n         pVzcP5HFOVsVrqy6PXpAuMpwdNqDz3yE6KO+ZUtEmlbX3/oIHN5rg4GTVinrWCdsPqoi\n         lPeQ==","X-Forwarded-Encrypted":"i=1;\n AJvYcCWi5zNFccZx5eBATqhMMqRTyRSqpdS/Fw8eS9NJQApWHYwDs7JdGJwKvdKW3STAZuLxiuSvKGIhvdWTb/E=@lists.ozlabs.org","X-Gm-Message-State":"AOJu0YxrJxhlhvKa/MZVN3q0NN/pLzo2M1c322opj1mixsZzXIQFyf16\n\tdmdjCTKl15ggutTm0wS8IEF5/2ypIJii9btfTs+6FQzHLowkjhfRYdikLkDr5yNH+jM=","X-Gm-Gg":"AeBDieuBfV1/4i8BKwM7p3/WF9wDteH8cKmxOf0jyCXgGUQ5AS2Mrl4omWRi2mu/eU5\n\twZWBDP9MvtT1DkOFVZc36rGk1P5M/EIin71+Tz5jcU7aGuZglnpLg8IHq4vvyWg4m87skNuIKbt\n\tNrvNEbDLu0PsxYZkYcNBRJMlTVvuh9KdPsAHwrwlNRcGgw9+L2Hb1lQX99pZV9JhKsnIs6wIq6S\n\txA/MUtE995oJ5iBlWlC4Ng3tL2mIv0RaTkZdjjXskLxaUXDqSnHMDpbVllXXozoMZ5gAoyQWdPm\n\ta9x4LD6fToOUmC7oSZm50xF/g1fpMWDBIjWzTmMRsRQfN3zPUIL0CoSfgOq9dyHGYe/3TQFPLXr\n\tXFz3M6gqnvyzSRPDejls30bF4J372KiY4Ip+Jidesu3n+3eMu39PC9xfcMDaD45MhHWtQJkqNTB\n\t4j586cbGpWKNb3IXqPc/8+rE+e5GLLl9VAaJ1mjISY5C8=","X-Received":"by 2002:a17:90b:2b50:b0:35d:a6eb:197f with SMTP id\n 98e67ed59e1d1-35de660a696mr8364134a91.0.1775393667087;\n        Sun, 05 Apr 2026 05:54:27 -0700 (PDT)","From":"Muchun Song <songmuchun@bytedance.com>","To":"Andrew Morton <akpm@linux-foundation.org>,\n\tDavid Hildenbrand <david@kernel.org>,\n\tMuchun Song <muchun.song@linux.dev>,\n\tOscar Salvador <osalvador@suse.de>,\n\tMichael Ellerman <mpe@ellerman.id.au>,\n\tMadhavan Srinivasan <maddy@linux.ibm.com>","Cc":"Lorenzo Stoakes <ljs@kernel.org>,\n\t\"Liam R . Howlett\" <Liam.Howlett@oracle.com>,\n\tVlastimil Babka <vbabka@kernel.org>,\n\tMike Rapoport <rppt@kernel.org>,\n\tSuren Baghdasaryan <surenb@google.com>,\n\tMichal Hocko <mhocko@suse.com>,\n\tNicholas Piggin <npiggin@gmail.com>,\n\tChristophe Leroy <chleroy@kernel.org>,\n\taneesh.kumar@linux.ibm.com,\n\tjoao.m.martins@oracle.com,\n\tlinux-mm@kvack.org,\n\tlinuxppc-dev@lists.ozlabs.org,\n\tlinux-kernel@vger.kernel.org,\n\tMuchun Song <songmuchun@bytedance.com>","Subject":"[PATCH 10/49] mm: move subsection_map_init() into sparse_init()","Date":"Sun,  5 Apr 2026 20:52:01 +0800","Message-Id":"<20260405125240.2558577-11-songmuchun@bytedance.com>","X-Mailer":"git-send-email 2.20.1","In-Reply-To":"<20260405125240.2558577-1-songmuchun@bytedance.com>","References":"<20260405125240.2558577-1-songmuchun@bytedance.com>","X-Mailing-List":"linuxppc-dev@lists.ozlabs.org","List-Id":"<linuxppc-dev.lists.ozlabs.org>","List-Help":"<mailto:linuxppc-dev+help@lists.ozlabs.org>","List-Owner":"<mailto:linuxppc-dev+owner@lists.ozlabs.org>","List-Post":"<mailto:linuxppc-dev@lists.ozlabs.org>","List-Archive":"<https://lore.kernel.org/linuxppc-dev/>,\n  <https://lists.ozlabs.org/pipermail/linuxppc-dev/>","List-Subscribe":"<mailto:linuxppc-dev+subscribe@lists.ozlabs.org>,\n  <mailto:linuxppc-dev+subscribe-digest@lists.ozlabs.org>,\n  <mailto:linuxppc-dev+subscribe-nomail@lists.ozlabs.org>","List-Unsubscribe":"<mailto:linuxppc-dev+unsubscribe@lists.ozlabs.org>","Precedence":"list","MIME-Version":"1.0","Content-Transfer-Encoding":"8bit","X-Spam-Status":"No, score=-0.2 required=3.0 tests=DKIM_SIGNED,DKIM_VALID,\n\tDKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS\n\tautolearn=disabled version=4.0.1 OzLabs 8","X-Spam-Checker-Version":"SpamAssassin 4.0.1 (2024-03-25) on lists.ozlabs.org"},"content":"Move the initialization of the subsection map from free_area_init()\ninto sparse_init(). This encapsulates the logic within the sparse\nmemory initialization code.\n\nSigned-off-by: Muchun Song <songmuchun@bytedance.com>\n---\n mm/internal.h       |  5 ++---\n mm/mm_init.c        | 10 ++--------\n mm/sparse-vmemmap.c | 11 ++++++++++-\n mm/sparse.c         |  1 +\n 4 files changed, 15 insertions(+), 12 deletions(-)","diff":"diff --git a/mm/internal.h b/mm/internal.h\nindex edb1c04d0617..d70075d0e788 100644\n--- a/mm/internal.h\n+++ b/mm/internal.h\n@@ -1004,10 +1004,9 @@ static inline void sparse_init(void) {}\n  * mm/sparse-vmemmap.c\n  */\n #ifdef CONFIG_SPARSEMEM_VMEMMAP\n-void sparse_init_subsection_map(unsigned long pfn, unsigned long nr_pages);\n+void sparse_init_subsection_map(void);\n #else\n-static inline void sparse_init_subsection_map(unsigned long pfn,\n-\t\tunsigned long nr_pages)\n+static inline void sparse_init_subsection_map(void)\n {\n }\n #endif /* CONFIG_SPARSEMEM_VMEMMAP */\ndiff --git a/mm/mm_init.c b/mm/mm_init.c\nindex a92c5053f63d..5ca4503e7622 100644\n--- a/mm/mm_init.c\n+++ b/mm/mm_init.c\n@@ -1857,18 +1857,12 @@ static void __init free_area_init(void)\n \t\t\t       (u64)zone_movable_pfn[i] << PAGE_SHIFT);\n \t}\n \n-\t/*\n-\t * Print out the early node map, and initialize the\n-\t * subsection-map relative to active online memory ranges to\n-\t * enable future \"sub-section\" extensions of the memory map.\n-\t */\n+\t/* Print out the early node map. */\n \tpr_info(\"Early memory node ranges\\n\");\n-\tfor_each_mem_pfn_range(i, MAX_NUMNODES, &start_pfn, &end_pfn, &nid) {\n+\tfor_each_mem_pfn_range(i, MAX_NUMNODES, &start_pfn, &end_pfn, &nid)\n \t\tpr_info(\"  node %3d: [mem %#018Lx-%#018Lx]\\n\", nid,\n \t\t\t(u64)start_pfn << PAGE_SHIFT,\n \t\t\t((u64)end_pfn << PAGE_SHIFT) - 1);\n-\t\tsparse_init_subsection_map(start_pfn, end_pfn - start_pfn);\n-\t}\n \n \t/* Initialise every node */\n \tmminit_verify_pageflags_layout();\ndiff --git a/mm/sparse-vmemmap.c b/mm/sparse-vmemmap.c\nindex 0ee03db0b22f..b7201c235419 100644\n--- a/mm/sparse-vmemmap.c\n+++ b/mm/sparse-vmemmap.c\n@@ -603,7 +603,7 @@ static void subsection_mask_set(unsigned long *map, unsigned long pfn,\n \tbitmap_set(map, idx, end - idx + 1);\n }\n \n-void __init sparse_init_subsection_map(unsigned long pfn, unsigned long nr_pages)\n+static void __init sparse_init_subsection_map_range(unsigned long pfn, unsigned long nr_pages)\n {\n \tint end_sec_nr = pfn_to_section_nr(pfn + nr_pages - 1);\n \tunsigned long nr, start_sec_nr = pfn_to_section_nr(pfn);\n@@ -626,6 +626,15 @@ void __init sparse_init_subsection_map(unsigned long pfn, unsigned long nr_pages\n \t}\n }\n \n+void __init sparse_init_subsection_map(void)\n+{\n+\tint i, nid;\n+\tunsigned long start, end;\n+\n+\tfor_each_mem_pfn_range(i, MAX_NUMNODES, &start, &end, &nid)\n+\t\tsparse_init_subsection_map_range(start, end - start);\n+}\n+\n #ifdef CONFIG_MEMORY_HOTPLUG\n \n /* Mark all memory sections within the pfn range as online */\ndiff --git a/mm/sparse.c b/mm/sparse.c\nindex 5c12b979a618..c7f91dc2e5b5 100644\n--- a/mm/sparse.c\n+++ b/mm/sparse.c\n@@ -424,5 +424,6 @@ void __init sparse_init(void)\n \t}\n \t/* cover the last node */\n \tsparse_init_nid(nid_begin, pnum_begin, pnum_end, map_count);\n+\tsparse_init_subsection_map();\n \tvmemmap_populate_print_last();\n }\n","prefixes":["10/49"]}