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 AA085CA0EED for ; Fri, 22 Aug 2025 17:08:37 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id C5E98440156; Fri, 22 Aug 2025 13:08:36 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id C102E8E009D; Fri, 22 Aug 2025 13:08:36 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id AD7FF440156; Fri, 22 Aug 2025 13:08:36 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0013.hostedemail.com [216.40.44.13]) by kanga.kvack.org (Postfix) with ESMTP id 98AA78E009D for ; Fri, 22 Aug 2025 13:08:36 -0400 (EDT) Received: from smtpin18.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id 2E2C91D93A1 for ; Fri, 22 Aug 2025 17:08:36 +0000 (UTC) X-FDA: 83805027432.18.8FAEC14 Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.15]) by imf28.hostedemail.com (Postfix) with ESMTP id 4A69DC0007 for ; Fri, 22 Aug 2025 17:08:33 +0000 (UTC) Authentication-Results: imf28.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=UdisCh3a; dmarc=pass (policy=none) header.from=intel.com; spf=pass (imf28.hostedemail.com: domain of dave.hansen@intel.com designates 198.175.65.15 as permitted sender) smtp.mailfrom=dave.hansen@intel.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1755882514; 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=I+zeuBCV3lD21/NePvOgV00gPcMhgZnQViHE0XNFm/c=; b=u99h5ARn2hFHwSL9qOgNTQ9/lrWs09zBnZL2844ObGIcJS6OIl+Z1qsdKLM7DDzPhGv276 Ao845Ry0hh0R/Z7obq3Gs6ApHrmOdeJivFwl19bJI0CUs7XwC7ctgHMepC8w0t6pgDVy9A LiUAoGpK/unlDkpfNd9U64pvHHjSbE0= ARC-Authentication-Results: i=1; imf28.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=UdisCh3a; dmarc=pass (policy=none) header.from=intel.com; spf=pass (imf28.hostedemail.com: domain of dave.hansen@intel.com designates 198.175.65.15 as permitted sender) smtp.mailfrom=dave.hansen@intel.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1755882514; a=rsa-sha256; cv=none; b=cQsZTGQKyotS4GOcisYatCj59tYPl3Ezv/mPPszysib80UmhG0wywnCnRs7z5B+R/CjZJZ xUlRX4Z41ieMB7Q7TByrjbuNhIBarBTJU4smFOvCOHQDHupWnUqwDcAq+yW9+os4J+feXX LO5zeEOys1LI7Tg/MI2EwJfa2KvCtQU= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1755882514; x=1787418514; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=3YE+ZQ5vrX6aLU86H7BJlfzyReIaU+5+8eV+03TzXIE=; b=UdisCh3aO1k4opOUZ2oyZsUiursTw0kvOVJk3awJnEBVj7mrjPgxrllr DqOZ4d840wLVxG+jmuZHSrYBgJPIC1xIbA8g2cH5bUwKYTh/GTB1H9Gux OR4DYYPqTWyKwWtz2z2wXYtWvqy/GEPnfCJxNgbTG08ybM4aBamNyYFZ0 jfptxmTsA5oJLMiOWlEKHGhE4CV0KJfghWkg5/mB/YwRNzjmGs5klqkVY hDnXVP/orq1pHT3Yh/9ORguz5wtWALqM17HTwDZHFaWvsc1eArTy3R5eV D955f2YU8ABbpTqXvPdoNgpxQ/cKybEOc0pRzLp1CD5fjyTuwS487+Puw A==; X-CSE-ConnectionGUID: lrBRtMZmTzSw3av97svimA== X-CSE-MsgGUID: qaxi2KVlQla7ovZTSpu6YA== X-IronPort-AV: E=McAfee;i="6800,10657,11529"; a="61840254" X-IronPort-AV: E=Sophos;i="6.17,312,1747724400"; d="scan'208";a="61840254" Received: from orviesa005.jf.intel.com ([10.64.159.145]) by orvoesa107.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Aug 2025 10:08:32 -0700 X-CSE-ConnectionGUID: 5Nu5hnUPTz+8m2WU1ivarg== X-CSE-MsgGUID: YdsZ6B6rSVa6oYkMnHlSKw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.17,312,1747724400"; d="scan'208";a="174065694" Received: from tfalcon-desk.amr.corp.intel.com (HELO [10.125.108.168]) ([10.125.108.168]) by orviesa005-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Aug 2025 10:08:31 -0700 Message-ID: <79027c6f-f2f3-41b2-9ff3-c5576fc06c5c@intel.com> Date: Fri, 22 Aug 2025 10:08:30 -0700 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v2] mm: fix KASAN build error due to p*d_populate_kernel() To: Harry Yoo Cc: Liam.Howlett@oracle.com, akpm@linux-foundation.org, andreyknvl@gmail.com, aneesh.kumar@linux.ibm.com, anshuman.khandual@arm.com, apopple@nvidia.com, ardb@kernel.org, arnd@arndb.de, bp@alien8.de, cl@gentwo.org, dave.hansen@linux.intel.com, david@redhat.com, dennis@kernel.org, dev.jain@arm.com, dvyukov@google.com, glider@google.com, gwan-gyeong.mun@intel.com, hpa@zyccr.com, jane.chu@oracle.com, jgross@suse.de, jhubbard@nvidia.com, joao.m.martins@oracle.com, joro@8bytes.org, kas@kernel.org, kevin.brodsky@arm.com, linux-arch@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, lorenzo.stoakes@oracle.com, luto@kernel.org, maobibo@loongson.cn, mhocko@suse.com, mingo@redhat.com, osalvador@suse.de, peterx@redhat.com, peterz@infradead.org, rppt@kernel.org, ryabinin.a.a@gmail.com, ryan.roberts@arm.com, stable@vger.kernel.org, surenb@google.com, tglx@linutronix.de, thuth@redhat.com, tj@kernel.org, urezki@gmail.com, vbabka@suse.cz, vincenzo.frascino@arm.com, x86@kernel.org, zhengqi.arch@bytedance.com References: <20250821093542.37844-1-harry.yoo@oracle.com> <20250821115731.137284-1-harry.yoo@oracle.com> <3976ef5d-a959-408a-b538-7feba1f0ab7a@intel.com> From: Dave Hansen Content-Language: en-US Autocrypt: addr=dave.hansen@intel.com; keydata= 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 In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Rspamd-Server: rspam07 X-Rspamd-Queue-Id: 4A69DC0007 X-Stat-Signature: t69z4tk8ueg6ztd176qfu356b1qdfkbh X-Rspam-User: X-HE-Tag: 1755882513-722607 X-HE-Meta: U2FsdGVkX1/Bzpl4GLwOwL9q+T+HSV/qQn2t9dir8o3G0XpPFDCfa+sWs6f1ECzT4vGxA+uQ6hkF7AkHufXdaltIenGW04kcU/aMLC9N4/QvdNDu+YUiAJZxDM443vt1Fmxsr5EUg8snU2pVrrDWF6dHt1qmd2mpJgdt+bo0Yo7+62qZGb+9Dw09nACepY8aGHIulrPJcl2LYZumeeWVkCPGRAQs/jIwAMCmKhAuO14o+BG0gAGR45D8+Ri/woumypr8p0kYs4yGonHMZP7OJCgbRtAsbX51MnDGrAe3Hnfh4lhdP7llfYIAIdO5benb0btiA1wGa+U1ue3ojnPzTY3PHx1a/zE/+Lxq5t5iKwlCXunf0MH1CPF2QfQJe0Or9cpwdr78qkJbi0o+9369BRiok4RLjnQGGYFyTmqGncOvfZHkaMyaZxQRGsmd/M+EcMBbPf6ioATn7htMxtU94fOD4PNOJCYgvP5vrTMLh7y1BmfWW8+99yhgAdc6CLJl0a732O3cKY++EvotIQB1uWfX5EUiLly3zaWQxSP9QMwM6rv6QiVdhtKW2niZwmx5wPtC5P4bN8e1+q2lh1gpjxv+b1PUohVNIfUx5SO19X+a5s2DJj+q77CHaslSoRYA4bd99AsJ4LRFZgu1NXxetD0gLtCLb7CgV612ReBnVJprXH5rW5OHC9IGwQl49JkWhvfbBOXiceFqXYrbvZdXLSsq54hG9SZyc2lBFzPTb98sQH/bwGjTClXXy4t7+H92XUukvysYLTwpMbwnRzcPWvutT/S+vu5r+zkQiRUxT7PBLFV7taBwyTb1/6/hBXnoWPiXVz/bq4zggDunDT44Lm2mmpBWw4SMdfwv16CEznTlyjD/mUjh9FKfAP+gJO4ZFtfK1mhZ9PpY+oN/FwgQnxHXSxSoXxct0jc2WBfZDavPlQ6+GjFnUjgwb6/UdTHLnYqO8WSCyxG1/chvUuA E3B6Dv2r /8rYlf1YYIkJU6vCTyeXQ/bRdM2kF0eMBey/Mt9gAJyjRVSOS9+S8pEbl2xhrsxtFvV8sJg0cEVNfqCLo9kgZVnEHKuqUGqpsDbgCkTYlHfbe50fN1rjdTdBrgMBz+P0Lz52bb1K1iIDxUHRvtYFebCYH/4pAzJd6c+zb4Ov8btMacz5U/F2wcs5kEczTXWml9Aja1O/hJKstGxG8W6yCBrIb3EN1+asbPCFapNQIj8/C+59wQebYiO9/3ysajKRbTt6hZpk4ksjRqNgxB/NFJ6UEyRBNfYZc0Z8l8xadSMe6TEWuCj9bA4hb3ZqeFzZn1xcp5YAkadyuock= 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 8/21/25 18:11, Harry Yoo wrote: > On Thu, Aug 21, 2025 at 10:36:12AM -0700, Dave Hansen wrote: >> On 8/21/25 04:57, Harry Yoo wrote: >>> However, {pgd,p4d}_populate_kernel() is defined as a function regardless >>> of the number of page table levels, so the compiler may not optimize >>> them away. In this case, the following linker error occurs: > > Hi, thanks for taking a look, Dave! > > First of all, this is a fix-up patch of a mm-hotfixes patch series that > fixes a bug (I should have explained that in the changelog) [1]. > > [1] https://lore.kernel.org/linux-mm/20250818020206.4517-1-harry.yoo@oracle.com > > I think we can continue discussing it and perhaps do that as part of > a follow-up series, because the current patch series need to be backported > to -stable and your suggestion to improve existing code doesn't require > -stable backports. > > Does that sound fine? > >> This part of the changelog confused me. I think it's focusing on the >> wrong thing. >> >> The code that's triggering this is literally: >> >>> pgd_populate(&init_mm, pgd, >>> lm_alias(kasan_early_shadow_p4d)); >> >> It sure _looks_ like it's unconditionally referencing the >> 'kasan_early_shadow_p4d' symbol. I think it's wrong to hide that with >> macro magic and just assume that the macros won't reference it. >> >> If a symbol isn't being defined, it shouldn't be referenced in C code.:q > > A fair point, and that's what KASAN code has been doing for years. > >> The right way to do it is to have an #ifdef in a header that avoids >> compiling in the reference to the symbol. > > You mean defining some wrapper functions for p*d_populate_kernel() in > KASAN with different implementations based on ifdeffery? That would work. So would something like: #if CONFIG_PGTABLE_LEVELS >= 4 extern p4d_t kasan_early_shadow_p4d[MAX_PTRS_PER_P4D]; #else #define kasan_early_shadow_p4d NULL #endif > Just to clarify, what should be the exact ifdeffery to cover these cases? > #if CONFIG_PGTABLE_LEVELS == 4 and 5, or > #ifdef __PAGETABLE_P4D_FOLDED and __PAGETABLE_PUD_FOLDED ? > > I have no strong opinion on this, let's hear what KASAN folks think. I think CONFIG_PGTABLE_LEVELS works, but in the end I'm not picky about the specific #ifdefs that work.