From patchwork Tue Mar 25 12:15:57 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Guo Ren X-Patchwork-Id: 14028532 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 DEF83C36005 for ; Tue, 25 Mar 2025 12:20:38 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 3AACF280013; Tue, 25 Mar 2025 08:20:36 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 32FE828000C; Tue, 25 Mar 2025 08:20:36 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 18366280013; Tue, 25 Mar 2025 08:20:36 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0014.hostedemail.com [216.40.44.14]) by kanga.kvack.org (Postfix) with ESMTP id EAAFC28000C for ; Tue, 25 Mar 2025 08:20:35 -0400 (EDT) Received: from smtpin18.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay10.hostedemail.com (Postfix) with ESMTP id C7E35C10D9 for ; Tue, 25 Mar 2025 12:20:37 +0000 (UTC) X-FDA: 83259981714.18.9AADE64 Received: from sea.source.kernel.org (sea.source.kernel.org [172.234.252.31]) by imf21.hostedemail.com (Postfix) with ESMTP id D73E71C001B for ; Tue, 25 Mar 2025 12:20:35 +0000 (UTC) Authentication-Results: imf21.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=YGv7Ju8F; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf21.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1742905236; a=rsa-sha256; cv=none; b=fER4bX/GkdOPKNKx6K6XxVaTRpDLL2eHJiKjpS22hpaQzZkGejCZcXcDUUmVwewU/CzqXK s4Aw7gj/nL0nraen28JOv7tGQEvJvtmS8/ycq1L+8Htx1Vk8OmzgNOf35IvCXwdKWXfI3g QJSV6TndxvXVq1nwjSTWpUlMcp2QUM4= ARC-Authentication-Results: i=1; imf21.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=YGv7Ju8F; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf21.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1742905236; 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=OVMI22T/HUnY+rovp7Nbq+t2tY3CgOetQ78DrZLtbIY=; b=WHIBe30MxhQznr8A3kAx1XdvacFqaITAbGZJaRomBKjry1B8kHAQ+QkQQ6P8nZSSNiiQIH 3e5kzR3hPj4+JvZqLC7diijBDMc0Ykn2PGCY6Uk0GXkc328SHG1YSATw1dMcPlPwJvTxJF mfkAWL8Shh1ObkFAazOOzcrRBxzpOX0= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by sea.source.kernel.org (Postfix) with ESMTP id 790A343492; Tue, 25 Mar 2025 12:20:34 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 0E3FBC4CEEE; Tue, 25 Mar 2025 12:20:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1742905234; bh=IFZFjonaMzbpRZ4swpgyItEna4nE83LkZzb9BRzGITE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=YGv7Ju8FJqwJKAhoK+0bpefpHJmqwSqitCJQ3KA8SHoFBO3xjgZJGCnN1+EpM9Ri8 G0F8vKvx8n6+OSgZoVo+DMyBKKoIIhJSCP3taMQ5FZeWGN/R31z9hqNogcz/s/Onyr z7gFsqQn85faeI7gGJQLGHu93WAcoXryyyRSyQsANFNuhZaVIo6Dx8943m3kKw9yDg 27bjtFahCMk02wsXueW0/FZUhPIbW+fn3gQxchZIXU1nl5TX8/4hg5q3hXCN/9iqSh /WA528nukATyoTdAqfWLTZshpwfuMiYbtl8zLXtJpFV+4Wd+cfr5szXSWpIHHAHUjx 4Ts1fcwAE9wQQ== 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 16/43] rv64ilp32_abi: riscv: Support physical addresses >= 0x80000000 Date: Tue, 25 Mar 2025 08:15:57 -0400 Message-Id: <20250325121624.523258-17-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: D73E71C001B X-Stat-Signature: xm4i99hro6y7g73dtchdk69zbytuz3hh X-Rspam-User: X-Rspamd-Server: rspam06 X-HE-Tag: 1742905235-433442 X-HE-Meta: U2FsdGVkX1+oixmNySPhEOHaSb0iNhQGsRW5popTn7nCtmi/g26dJ7fPe8cba79xaAwdCwSQiOmmG4NiY9eEpM4n9HVi60bzDB44amfHP5aWv+mMk4p032P0vuTZ5zbzhVr0vJbMMarnFDJl4hkyiaix4tNvQeXLi3yFURxc/79pi/geii+Z1aIvQA+a5Odlmo6n0O3YGMdnRo6+1NtVuUqKVIljfIF9LqzIYQG4VA96uO+ZouMp59s4ACv8WPjft5xuJifYpRqZpW68W2c9fJ+K2GFspnxYHHPxuEZQ0AD+Q8rBbkGgXdo4mB3BdfGHRJyaGRJW6tEAANtOxv8sOdevIt+WtC/r4d1I1PgJ9LNswuhZGistB2b8DfH9DY8qz1M5x3MraDUcusTzmbhbytS0+SQq3F6sZJEfqAkOo5B4kpZITQlqJJVEJ0tK4U/kbNB//qFDnk0wst0Ivs4Zrvx34B321kga+fwwyHm0NNjXbvYhkm+EaentzTwAmkFCJOyYyCO5rXg5xjwOflsrG/cJi1mRKqVqipnmRRhhDbzUb4f2IG0qVe0LHfn7GEj1odBMUEMyRgVN6xdsqxPhPTguV6EZ9S41Pd0lDiQ+cPG0FwgS7IL8QJL8Ucb2CPXbMjZfu5EPl/jxW5QaJM9m3oMAV1pe1w9/+NyvkL6DwNNmXXaDdxXFXWqdNLQh+a0u2jZ9ZVdzIGTg0jApMD/ltzZjIdIDszzLNN4Ia1N6azsp7B73dLQB5oXdELMlPVBnM2Cxwh1cXMzyReXEFauHfnMPww6OifKPyiTr23c93Pu9DkYet5+tmtF7IIWFp4C4njYSxl23+bh+eSjV3ZC+65pn72xITZBfNLOeGiUFxwRoaexVVXqwMhaMbgBQLZF9aFBzjut6DyJRG5EYt8MwcvhDEwQrX50+65RFVUNLQCVS07TYSVDFcQOYA6aA7uXomz+uMqlEg/OCCjZj1t1 TsqOzsm7 4K1D1QgavpBlSDQrv2Lw7AvOm534u0ksoCOM0Un1bTYAmEvW/WdV/gMS6u0liq66TeYIZpErIJ+Exi7doV6BksVXrTr1KEwLNxbQFu128pKanvbv39GAmwf4gK8vfBUQ1Z6rGm+x/G/Ib2Qi+MehOfWmZZnkMgCLJsUNa1ZkqLImGf6Gd/XJG6tXTcwJLPAIm2K0USy+jL7G6ygF2+L+Rt+3cE8t6uaMFiXaAktV/Sqf+SsP0HoCTOkBS1hyWbBkD9+WtXu2BK82aG3r7BhcJzS1ImiEbydRM0pWfr32nA4T/BKp5WY3LARrnHwB0EXmaZJgN1UazaLl0F9L8Msr9rsixcC/fxG8FZkXe 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)" The RV64ILP32 ABI has two independent 2GiB address space: - 0 ~ 0x7fffffff - 0xffffffff80000000 ~ 0xffffffffffffffff In the rv64ilp32 ABI, 0x80000000 is illegal; hence, use a temporary trap handler to zero-extend the address for jalr, load and store operations. Signed-off-by: Guo Ren (Alibaba DAMO Academy) --- arch/riscv/kernel/head.S | 112 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 112 insertions(+) diff --git a/arch/riscv/kernel/head.S b/arch/riscv/kernel/head.S index e55a92be12b1..bd2f30aa6d01 100644 --- a/arch/riscv/kernel/head.S +++ b/arch/riscv/kernel/head.S @@ -170,6 +170,118 @@ secondary_start_sbi: .align 2 .Lsecondary_park: +#ifdef CONFIG_ABI_RV64ILP32 +.option push +.option norelax +.option norvc + addiw sp, sp, -32 + + /* zext.w sp */ + slli sp, sp, 32 + srli sp, sp, 32 + + /* zext.w ra */ + slli ra, ra, 32 + srli ra, ra, 32 + + /* zext.w fp */ + slli fp, fp, 32 + srli fp, fp, 32 + + /* zext.w tp */ + slli tp, tp, 32 + srli tp, tp, 32 + + /* save tmp reg */ + REG_S ra, 24(sp) + REG_S fp, 16(sp) + REG_S tp, 8(sp) + REG_S gp, 0(sp) + + /* zext.w epc */ + csrr ra, CSR_EPC + slli ra, ra, 32 + srli ra, ra, 32 + csrw CSR_SEPC, ra + + csrr gp, CSR_CAUSE + + /* EXC_INST_ACCESS */ + addiw fp, gp, -1 + beqz fp, 6f + + /* EXC_LOAD_ACCESS */ + addiw fp, gp, -5 + beqz fp, 1f + + /* EXC_STORE_ACCESS */ + addiw fp, gp, -7 + beqz fp, 1f + + j 7f +1: + /* get inst */ + lw ra, 0(ra) + andi gp, ra, 0x3 + + /* c.(lw/sw/ld/sd)sp */ + addiw fp, gp, -2 + beqz fp, 6f + + /* lw/sw/ld/sd */ + addiw fp, gp, -3 + beqz fp, 2f + + /* c.(lw/sw/ld/sd) */ + li fp, 0x7 + slli fp, fp, 7 + and ra, fp, ra + slli ra, ra, 8 + j 3f + +2: + /* get rs1 */ + li fp, 0x1f + slli fp, fp, 15 + and ra, fp, ra + +3: + /* copy rs1 to rd */ + mv fp, ra + srli fp, fp, 8 + or ra, fp, ra + + /* modify slli */ + la fp, 4f + lw tp, 0(fp) + mv gp, tp + or tp, ra, tp + sw tp, 0(fp) + fence.i +4: slli x0, x0, 32 + sw gp, 0(fp) + + /* modify srli */ + la fp, 5f + lw tp, 0(fp) + mv gp, tp + or tp, ra, tp + sw tp, 0(fp) + fence.i +5: srli x0, x0, 32 + sw gp, 0(fp) + +6: + /* restore tmp reg */ + REG_L ra, 24(sp) + REG_L fp, 16(sp) + REG_L tp, 8(sp) + REG_L gp, 0(sp) + addi sp, sp, 32 + sret +.option pop +7: +#endif /* * Park this hart if we: * - have too many harts on CONFIG_RISCV_BOOT_SPINWAIT