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 lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 48938C433F5 for ; Sat, 12 Feb 2022 01:06:13 +0000 (UTC) Received: from localhost ([::1]:55712 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1nIgrc-0003Vz-0d for qemu-devel@archiver.kernel.org; Fri, 11 Feb 2022 20:06:12 -0500 Received: from eggs.gnu.org ([209.51.188.92]:37514) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1nIftZ-0000Vg-AK for qemu-devel@nongnu.org; Fri, 11 Feb 2022 19:04:09 -0500 Received: from esa6.hgst.iphmx.com ([216.71.154.45]:7902) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1nIftW-0000Wm-2x for qemu-devel@nongnu.org; Fri, 11 Feb 2022 19:04:08 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=wdc.com; i=@wdc.com; q=dns/txt; s=dkim.wdc.com; t=1644624247; x=1676160247; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=5M2juYO1XBdVp0HXJg8qxnDJ7Bn+5MPFeReNPxd/vPE=; b=EfWbTIJkGFRkdNWqAguFfA1Lo1IkWZDHgclP7qr5u3UBZgvd7MygZk7k rtpe9ostskfujlvl0z01GhUXSPN+egOMRg5bjl/fzjz5Wa7/fWHMSpkxM 7Bm2e39Tzo2iIXpCu229IbT1tNSqozXFLBSZpfp3Uku6rTqP2eeDZygd1 5dHzZh25c6b6MD2KbAY+yN4/b2oNMdwMlwKVvhJvZYTYEgtOjy7Dkefn4 9fSLXQ9nqMNuPiXZtiIBpUE+/gYL8ttuzbp3DFFxkqP48/HW8WI8DGw+X yVRe4JISxyFPmUjMHD8n3mPBmQBFkypR7JW/89p8+QaDFwSUAB/1iBafH A==; X-IronPort-AV: E=Sophos;i="5.88,361,1635177600"; d="scan'208";a="193710292" Received: from h199-255-45-15.hgst.com (HELO uls-op-cesaep02.wdc.com) ([199.255.45.15]) by ob1.hgst.iphmx.com with ESMTP; 12 Feb 2022 08:04:00 +0800 IronPort-SDR: Fy2oMyhfCt5bI2n0vX7xfIDmtcMVlkpPFQmgtosVhiwxbC5kiGCEpsfb1zHdqBVVGIpi8FIXZ3 FfhgV/z1OsDOJmJH5QtDur0A4XThKDXqY7eJTACUfdqKLcU+4O7Ng6YYc4GfIXkeQlWqioTQpQ 6nw3NQ0QL8+e3jdFJR4SJ3Z+aKEld/cuue6/JghWIFAcydpehz/15GWnXJhRjn9Z1fPNQMSZii GtThyVJ95YDh9IGYJEORAeC9UuUlYsp6a28gx+4HkJxPkOZXGyUXrDpQlyIy8pFmv+rsXNoIwC AVFDrG2APhgoiTjrKcB3eCis Received: from uls-op-cesaip02.wdc.com ([10.248.3.37]) by uls-op-cesaep02.wdc.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Feb 2022 15:35:44 -0800 IronPort-SDR: IK/nlkOihpmNBvMntcbms2sGgSIMTHPVnVPepfQI0oek0ATAX/m64J+6xRwEa82T6sJF6Qrojm w7E8hX4EuY2POzhchKiDWa0ZhBUVm1sNmgtYeXH5Hbt+1WbMacnjggtFcBJFLX+vFkbcUXRfiU UCmMCTLWk9VbCMQuTGk3ReRnInDJVF5SpF2dG/5fj4Mz+d4r/F8ssyg6t+XvtHMPciVu4hi8RH WJUBJ75+gLDzXZifeNITUVPYC0x0dHC7z17xkXTpMe8mnpqxdomY4TQoAXl/WKJJuaq/aGYY2X jT0= WDCIronportException: Internal Received: from usg-ed-osssrv.wdc.com ([10.3.10.180]) by uls-op-cesaip02.wdc.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Feb 2022 16:03:59 -0800 Received: from usg-ed-osssrv.wdc.com (usg-ed-osssrv.wdc.com [127.0.0.1]) by usg-ed-osssrv.wdc.com (Postfix) with ESMTP id 4JwW1B4nB1z1SVp1 for ; Fri, 11 Feb 2022 16:03:58 -0800 (PST) Authentication-Results: usg-ed-osssrv.wdc.com (amavisd-new); dkim=pass reason="pass (just generated, assumed good)" header.d=opensource.wdc.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d= opensource.wdc.com; h=content-transfer-encoding:mime-version :references:in-reply-to:x-mailer:message-id:date:subject:to :from; s=dkim; t=1644624238; x=1647216239; bh=5M2juYO1XBdVp0HXJg 8qxnDJ7Bn+5MPFeReNPxd/vPE=; b=eCFk/iFpaLAne7NVI/a83BIN0vTfsAUyx6 RGwIGAxYsZJDyIKDTh9fXMmKDKE8hh/463dGq7NCCRfopRxWmk8J+wTMVvXhufEB vviJNHJtAM6lzrvDCbV0AYQm0ldU37e2GvW6zkVNbTa3lqhgKFaBtJ1grZTYS26V N7r5bofTuw8rZxgBPzMd15lsDxXYBtpVeWuyPxZ6WOF304cOHRC34Hg8UptRwFa/ vBuQR6fAzrXoIqc2YsP+1IEois2i99XuvJA7/Y+t5gMOySmr6Tpj37TlcED7yAwN l1WoXWKnioeLndwpXyqpRpCu+kkj7PZogtGSFCgofA2gi76V9klw== X-Virus-Scanned: amavisd-new at usg-ed-osssrv.wdc.com Received: from usg-ed-osssrv.wdc.com ([127.0.0.1]) by usg-ed-osssrv.wdc.com (usg-ed-osssrv.wdc.com [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id mFKRmvPpifJ4 for ; Fri, 11 Feb 2022 16:03:58 -0800 (PST) Received: from toolbox.wdc.com (unknown [10.225.165.96]) by usg-ed-osssrv.wdc.com (Postfix) with ESMTPSA id 4JwW164KxYz1Rwrw; Fri, 11 Feb 2022 16:03:54 -0800 (PST) From: Alistair Francis To: qemu-devel@nongnu.org Cc: alistair23@gmail.com, Weiwei Li , Junqiang Wang , Anup Patel , Alistair Francis Subject: [PULL 37/40] target/riscv: add support for svnapot extension Date: Sat, 12 Feb 2022 10:00:28 +1000 Message-Id: <20220212000031.3946524-38-alistair.francis@opensource.wdc.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220212000031.3946524-1-alistair.francis@opensource.wdc.com> References: <20220212000031.3946524-1-alistair.francis@opensource.wdc.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Received-SPF: pass client-ip=216.71.154.45; envelope-from=prvs=03511bb56=alistair.francis@opensource.wdc.com; helo=esa6.hgst.iphmx.com X-Spam_score_int: -43 X-Spam_score: -4.4 X-Spam_bar: ---- X-Spam_report: (-4.4 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_MED=-2.3, SPF_HELO_PASS=-0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+qemu-devel=archiver.kernel.org@nongnu.org Sender: "Qemu-devel" From: Weiwei Li - add PTE_N bit - add PTE_N bit check for inner PTE - update address translation to support 64KiB continuous region (napot_bi= ts =3D 4) Signed-off-by: Weiwei Li Signed-off-by: Junqiang Wang Reviewed-by: Anup Patel Reviewed-by: Alistair Francis Message-Id: <20220204022658.18097-4-liweiwei@iscas.ac.cn> Signed-off-by: Alistair Francis --- target/riscv/cpu_bits.h | 1 + target/riscv/cpu.c | 2 ++ target/riscv/cpu_helper.c | 18 +++++++++++++++--- 3 files changed, 18 insertions(+), 3 deletions(-) diff --git a/target/riscv/cpu_bits.h b/target/riscv/cpu_bits.h index b3489cbc10..37ed4da72c 100644 --- a/target/riscv/cpu_bits.h +++ b/target/riscv/cpu_bits.h @@ -561,6 +561,7 @@ typedef enum { #define PTE_A 0x040 /* Accessed */ #define PTE_D 0x080 /* Dirty */ #define PTE_SOFT 0x300 /* Reserved for Software */ +#define PTE_N 0x8000000000000000ULL /* NAPOT translation *= / =20 /* Page table PPN shift amount */ #define PTE_PPN_SHIFT 10 diff --git a/target/riscv/cpu.c b/target/riscv/cpu.c index 9dce57a380..fda99c2a81 100644 --- a/target/riscv/cpu.c +++ b/target/riscv/cpu.c @@ -774,6 +774,8 @@ static Property riscv_cpu_properties[] =3D { DEFINE_PROP_UINT16("vlen", RISCVCPU, cfg.vlen, 128), DEFINE_PROP_UINT16("elen", RISCVCPU, cfg.elen, 64), =20 + DEFINE_PROP_BOOL("svnapot", RISCVCPU, cfg.ext_svnapot, false), + DEFINE_PROP_BOOL("zba", RISCVCPU, cfg.ext_zba, true), DEFINE_PROP_BOOL("zbb", RISCVCPU, cfg.ext_zbb, true), DEFINE_PROP_BOOL("zbc", RISCVCPU, cfg.ext_zbc, true), diff --git a/target/riscv/cpu_helper.c b/target/riscv/cpu_helper.c index 25ebc76725..437c9488a6 100644 --- a/target/riscv/cpu_helper.c +++ b/target/riscv/cpu_helper.c @@ -753,6 +753,8 @@ static int get_physical_address(CPURISCVState *env, h= waddr *physical, bool use_background =3D false; hwaddr ppn; RISCVCPU *cpu =3D env_archcpu(env); + int napot_bits =3D 0; + target_ulong napot_mask; =20 /* * Check if we should use the background registers for the two @@ -937,7 +939,7 @@ restart: return TRANSLATE_FAIL; } else if (!(pte & (PTE_R | PTE_W | PTE_X))) { /* Inner PTE, continue walking */ - if (pte & (PTE_D | PTE_A | PTE_U)) { + if (pte & (PTE_D | PTE_A | PTE_U | PTE_N)) { return TRANSLATE_FAIL; } base =3D ppn << PGSHIFT; @@ -1013,8 +1015,18 @@ restart: /* for superpage mappings, make a fake leaf PTE for the TLB'= s benefit. */ target_ulong vpn =3D addr >> PGSHIFT; - *physical =3D ((ppn | (vpn & ((1L << ptshift) - 1))) << PGSH= IFT) | - (addr & ~TARGET_PAGE_MASK); + + if (cpu->cfg.ext_svnapot && (pte & PTE_N)) { + napot_bits =3D ctzl(ppn) + 1; + if ((i !=3D (levels - 1)) || (napot_bits !=3D 4)) { + return TRANSLATE_FAIL; + } + } + + napot_mask =3D (1 << napot_bits) - 1; + *physical =3D (((ppn & ~napot_mask) | (vpn & napot_mask) | + (vpn & (((target_ulong)1 << ptshift) - 1)) + ) << PGSHIFT) | (addr & ~TARGET_PAGE_MASK); =20 /* set permissions on the TLB entry */ if ((pte & PTE_R) || ((pte & PTE_X) && mxr)) { --=20 2.34.1