From patchwork Tue Mar 25 12:15:58 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Guo Ren X-Patchwork-Id: 14028533 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 A5FF8C35FFC for ; Tue, 25 Mar 2025 12:20:53 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id ED8FB280014; Tue, 25 Mar 2025 08:20:50 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id EB0B528000C; Tue, 25 Mar 2025 08:20:50 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id D527D280014; Tue, 25 Mar 2025 08:20:50 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0012.hostedemail.com [216.40.44.12]) by kanga.kvack.org (Postfix) with ESMTP id B8AA528000C for ; Tue, 25 Mar 2025 08:20:50 -0400 (EDT) Received: from smtpin16.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay08.hostedemail.com (Postfix) with ESMTP id 7D43214019D for ; Tue, 25 Mar 2025 12:20:52 +0000 (UTC) X-FDA: 83259982344.16.A945BF4 Received: from sea.source.kernel.org (sea.source.kernel.org [172.234.252.31]) by imf01.hostedemail.com (Postfix) with ESMTP id B399E40013 for ; Tue, 25 Mar 2025 12:20:49 +0000 (UTC) Authentication-Results: imf01.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=Oz8iARGb; spf=pass (imf01.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1742905249; 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:in-reply-to:references:references:dkim-signature; bh=dhp3tuRMpN8WT3TqWoLq4g2nX9WRLQ5SojpCbOt/0jU=; b=sT7Igr1QP+BRo+HTqodOTaUhO438s6Y8u6wo+0+TTDK2adqUMlvzWf9N8Q4XMLntzHT9DN UHuTtcn4rMJDr+oH2lXEGJ8f65nVCQ9HV3uI+vfbMy4XdOwRcxMeYeR5vywRaIm1iQiRRV BKnhkTGhRqxEF1M9oaIAD/A1UW4gdQw= ARC-Authentication-Results: i=1; imf01.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=Oz8iARGb; spf=pass (imf01.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1742905249; a=rsa-sha256; cv=none; b=y2H7OL4rz7PV6ELg7ZIGiQXgdiAcPGaBBAz8EDGLSGq8v5HFZWKftyDQVMkVeKZg2WaQ6q J2UFUDW4cjWfZPC+Lk4LOpLQNfU4RIhxjSiu87b8bsGqqwA5e6DqMlRo1bW1hPM1PrkW0M /eDdIEqWAEAWfdtHaLDXvTOdUAxITFA= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by sea.source.kernel.org (Postfix) with ESMTP id 29C784389C; Tue, 25 Mar 2025 12:20:48 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 213B1C4CEE4; Tue, 25 Mar 2025 12:20:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1742905248; bh=j18oLXPHFjnaGmgCwscTDaPTneiSyVqaoCKba61TqXg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Oz8iARGb8tr7htUnaAeUCJ6IYWmPD2sUy6Fahrj1eenZT1kKMM+eFWJiKMQdGqcqw rqWz1qpr3jo3lVxFFYwrBasJ+tHw3PWT4Rv+apRvPWQa/i4K/2vaflC0hzKnPuX+P4 8bTM1EjGGpOTuQHdC8TBFwQkrFBcJI49u7thNpghWlOyMzJ3hMkq6mroidX2glUScJ uyG/XkFYIxn9NAsEUQSTt4TYvFJgoGc/h+TFjpPprvl74n7fsNLu4FNEPQT7I99tBn keJQj/Yhn5p3/N2C2J6YITPpmyRqNzvFWJV+jSwmuHsx+jq6dfD8Ek+CQ8ONbZxS8/ mQmFdBGqaAdYQ== From: guoren@kernel.org To: arnd@arndb.de, gregkh@linuxfoundation.org, torvalds@linux-foundation.org, paul.walmsley@sifive.com, palmer@dabbelt.com, anup@brainfault.org, atishp@atishpatra.org, oleg@redhat.com, kees@kernel.org, tglx@linutronix.de, will@kernel.org, mark.rutland@arm.com, brauner@kernel.org, akpm@linux-foundation.org, rostedt@goodmis.org, edumazet@google.com, unicorn_wang@outlook.com, inochiama@outlook.com, gaohan@iscas.ac.cn, shihua@iscas.ac.cn, jiawei@iscas.ac.cn, wuwei2016@iscas.ac.cn, drew@pdp7.com, prabhakar.mahadev-lad.rj@bp.renesas.com, ctsai390@andestech.com, wefu@redhat.com, kuba@kernel.org, pabeni@redhat.com, josef@toxicpanda.com, dsterba@suse.com, mingo@redhat.com, peterz@infradead.org, boqun.feng@gmail.com, guoren@kernel.org, xiao.w.wang@intel.com, qingfang.deng@siflower.com.cn, leobras@redhat.com, jszhang@kernel.org, conor.dooley@microchip.com, samuel.holland@sifive.com, yongxuan.wang@sifive.com, luxu.kernel@bytedance.com, david@redhat.com, ruanjinjie@huawei.com, cuiyunhui@bytedance.com, wangkefeng.wang@huawei.com, qiaozhe@iscas.ac.cn Cc: ardb@kernel.org, ast@kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, kvm@vger.kernel.org, kvm-riscv@lists.infradead.org, linux-mm@kvack.org, linux-crypto@vger.kernel.org, bpf@vger.kernel.org, linux-input@vger.kernel.org, linux-perf-users@vger.kernel.org, linux-serial@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-arch@vger.kernel.org, maple-tree@lists.infradead.org, linux-trace-kernel@vger.kernel.org, netdev@vger.kernel.org, linux-atm-general@lists.sourceforge.net, linux-btrfs@vger.kernel.org, netfilter-devel@vger.kernel.org, coreteam@netfilter.org, linux-nfs@vger.kernel.org, linux-sctp@vger.kernel.org, linux-usb@vger.kernel.org, linux-media@vger.kernel.org Subject: [RFC PATCH V3 17/43] rv64ilp32_abi: riscv: Adapt kasan memory layout Date: Tue, 25 Mar 2025 08:15:58 -0400 Message-Id: <20250325121624.523258-18-guoren@kernel.org> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20250325121624.523258-1-guoren@kernel.org> References: <20250325121624.523258-1-guoren@kernel.org> MIME-Version: 1.0 X-Rspamd-Queue-Id: B399E40013 X-Rspam-User: X-Rspamd-Server: rspam02 X-Stat-Signature: a96cg8qg83xrnrs85w6zbgrpssua58wg X-HE-Tag: 1742905249-657012 X-HE-Meta: U2FsdGVkX19kt1my7ahmlWLfx4E30EWz7rhQxzblRiMLMaSS2AxR9d5Q2n7OKoV8aLrA8M11pJtlOS7ffG8BYh5OyBKyK9/KrhTnlDwjf15cuzWyuy1yDwwd/gZEVsZQnQvRip5kRZ11YkFyFNa2aMSCqMcl6s4Ia0LZubO9KkMPLKckAFyDy9cbz1F8trMn/5TxmWDl/YtQu/znuDY6lo1W6KqKIGny88RSLYvGync19r8UiN7K6m4FYW070hvUhJzoXCU+0N/Z0oFaAJSjxkFgtpq7QTphaOajNU/zBi4JmJnV2p5qXDv73SWOL5rO8A17P8JKgeJ0s1CYSI/3yqarp3BbHzode9EHS0ghfeFH8RcqFHQu8k7ob8GVX1oRzHdFXTJYk1d6nQUNFa+kbOXhspTqdEu7XF6l2/lZvU9cM4tW5jb+0SxWmnj37tRQdiskrAo5uPgB0WAJV6xD4LHVcgZJb6BRrprDIwNas1rw+JDCxFtIcWmRdhmC/QPgFRxoS5eGuF1oT/uSDjnoMPSlBdtRaYaHarrb0prtQKf0zV8AYBjwjkdQxgbMiFNNH/4vND0NTHtUAN19CZjTPr6rF2Uw1SPAhVh26YXRLU3t9sPU3RT8n3Ks9ZJ3NkRqKHimlWquLJUg7xU9L7OCDevHnS8SvVWGaHaVv9WFqol17D9sFZVPm8cK0OkD/tMURzaP9FGXXSMBcUNUMt6d8NljhdnZc0aHWSrkLQHWoj5aVCQGiDSz8IyKaY2AkzbB/fyfKD1sTKu1Mw/Iezva2Lh3U5vBrVcaUp/s1YYTLuiMULEwwWqOZUBaRfglSfL30l7PxxvD9U7zTPc5N/7SZTZB/OKcPKDjD/nmMvFgRYVrTxtLSgcSddKPMjfazax6XTFPlDfFYBzK1AmQsYvAJ0x+U3drYFykMbRlDx6iHtlcUE+usDabxsnfbSn1j3UGAcFzPZ5BS/aYXCIEOvq s8gnNtb0 F/7FqsisRSuz5WOpy3txNYgXf8yhk5flQWCUSgLnfh+E1tuL5qoKWz2T6cfuMLs/L27duKnkoiEq3V1B2rdRmCwf1N9I+meK+Rndty9qoTh87Y4Zjn5yPrpqBi+EPJzgWq54d/8cvL9MzhBmquBpKv/apoloUNbVn7WXW5WTbs7kCACTtwgAifWJ2su7PvNjqXZw2xM1kRZ/VvtZ7dN/XXl7da+7MvwNluGs41j+W6X9hgi032UXwgH6IP+atQAc9vTUR3gOn3pOTn1UqfHnxdQryICwzGhsdgLUZ7u4758/sNDTz+Gs1es7dJXX7ngH0W3r/W4WWFzotj68AW+7lR1xDIZ6TX0iviRO/ 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: From: "Guo Ren (Alibaba DAMO Academy)" For generic KASAN, the size of each memory granule is 8, which needs 1/8 address space. The kernel space is 2GiB in rv64ilp32, so we need 256MiB range (0x80000000 ~ 0x90000000), and the offset is 0x7000000 for the whole 4GiB address space. Virtual kernel memory layout: fixmap : 0x90a00000 - 0x90ffffff (6144 kB) pci io : 0x91000000 - 0x91ffffff ( 16 MB) vmemmap : 0x92000000 - 0x93ffffff ( 32 MB) vmalloc : 0x94000000 - 0xb3ffffff ( 512 MB) modules : 0xb4000000 - 0xb7ffffff ( 64 MB) lowmem : 0xc0000000 - 0xc7ffffff ( 128 MB) kasan : 0x80000000 - 0x8fffffff ( 256 MB) <= kernel : 0xb8000000 - 0xbfffffff ( 128 MB) Signed-off-by: Guo Ren (Alibaba DAMO Academy) --- arch/riscv/include/asm/kasan.h | 6 +++++- arch/riscv/mm/kasan_init.c | 2 +- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/arch/riscv/include/asm/kasan.h b/arch/riscv/include/asm/kasan.h index e6a0071bdb56..dd3a211bc5d0 100644 --- a/arch/riscv/include/asm/kasan.h +++ b/arch/riscv/include/asm/kasan.h @@ -21,7 +21,7 @@ * [KASAN_SHADOW_OFFSET, KASAN_SHADOW_END) cover all 64-bits of virtual * addresses. So KASAN_SHADOW_OFFSET should satisfy the following equation: * KASAN_SHADOW_OFFSET = KASAN_SHADOW_END - - * (1ULL << (64 - KASAN_SHADOW_SCALE_SHIFT)) + * (1ULL << (BITS_PER_LONG - KASAN_SHADOW_SCALE_SHIFT)) */ #define KASAN_SHADOW_SCALE_SHIFT 3 @@ -31,7 +31,11 @@ * aligned on PGDIR_SIZE, so force its alignment to ease its population. */ #define KASAN_SHADOW_START ((KASAN_SHADOW_END - KASAN_SHADOW_SIZE) & PGDIR_MASK) +#if defined(CONFIG_64BIT) && (BITS_PER_LONG == 32) +#define KASAN_SHADOW_END 0x90000000UL +#else #define KASAN_SHADOW_END MODULES_LOWEST_VADDR +#endif #ifdef CONFIG_KASAN #define KASAN_SHADOW_OFFSET _AC(CONFIG_KASAN_SHADOW_OFFSET, UL) diff --git a/arch/riscv/mm/kasan_init.c b/arch/riscv/mm/kasan_init.c index 41c635d6aca4..1e864598779a 100644 --- a/arch/riscv/mm/kasan_init.c +++ b/arch/riscv/mm/kasan_init.c @@ -324,7 +324,7 @@ asmlinkage void __init kasan_early_init(void) uintptr_t i; BUILD_BUG_ON(KASAN_SHADOW_OFFSET != - KASAN_SHADOW_END - (1UL << (64 - KASAN_SHADOW_SCALE_SHIFT))); + KASAN_SHADOW_END - (1UL << (BITS_PER_LONG - KASAN_SHADOW_SCALE_SHIFT))); for (i = 0; i < PTRS_PER_PTE; ++i) set_pte(kasan_early_shadow_pte + i,