From patchwork Fri Feb 3 14:29:23 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Peter Maydell X-Patchwork-Id: 650041 Delivered-To: patch@linaro.org Received: by 2002:a17:522:d8c:b0:4be:c3dc:14d8 with SMTP id d12csp849562pva; Fri, 3 Feb 2023 06:31:01 -0800 (PST) X-Google-Smtp-Source: AK7set8XzLgwpGSCJAlUyZcJxHssoO/0C+X/jEui9K5Ul/r1SuHgvYPju88zEjBBqEcnvh5zsNaD X-Received: by 2002:a05:6102:32c3:b0:3d0:c826:599 with SMTP id o3-20020a05610232c300b003d0c8260599mr7677898vss.11.1675434660889; Fri, 03 Feb 2023 06:31:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1675434660; cv=none; d=google.com; s=arc-20160816; b=z+Fkr48DLvf0TLehVnK0u+C+XgOu6vO4BXWcwTmNGW0FFbbrByyLeX9kScQAKeHAea wT9+hAiyYNu86AadwYOyGWcTTJYBNnZ3HXwUENm6fdphbYpHZSAX7/8RtMsXtsDfZD0f uL2KfMFOXy67oBkF0dH1u8fKR11AAx9YruEo7elW0oYeK3ZVX91UFA10QxFP1hS9zV1H JSVwOJhsePWswm9pLAzbjlN1iohSzRB+qr1QHckke7NTRtHwm0nslwtd0Muxx5JAyhhA +aONEp2Ow667f7smcI09ojNj3fjL2L5IAYvsDp/urpLJE2X2HRWJxu0aBWGorEzuHEc2 ZrWw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=K2xxnob3/roFGLD087p6MyGRfXODxkAp5LJkBKCgYJQ=; b=W2D6Rc1nZRB36CXWgJeCJxUCrpQ6zmCS5TsYtgEzRjDOVahnALd5z9Xr3796Gu4k4j PdcebGlpZPFpa7Y9BP0Huf2VSS51bpMDmN10KvUVy5DhL2WosnCIQ9naGBpSlcchPnOn dF643XbZ/3KVF48jnscxQeL7ytI2bKfU/gxkBHgTLKSlbGJDyX8q5a4mIsoYDpXKW1Fh EXRgReeJzpvGeHT6NSrdq4YSaE4V+RQgBs3AKp/KU40Y3DFzJb+JOzxSOV8I+JfcQo3N e7TATGtFDjb1bOnwwKwNCqm0emTafU1nMSsusUXO1CZKmbDXpQ44e5q5dXWVJlx6ZcAb uKog== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=PisbtmTP; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id h23-20020a67f897000000b003f13e599481si737940vso.88.2023.02.03.06.31.00 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Fri, 03 Feb 2023 06:31:00 -0800 (PST) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=PisbtmTP; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1pNx5T-0008Mc-BU; Fri, 03 Feb 2023 09:30:47 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1pNx4f-0006pf-RW for qemu-devel@nongnu.org; Fri, 03 Feb 2023 09:29:57 -0500 Received: from mail-wm1-x335.google.com ([2a00:1450:4864:20::335]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1pNx4d-000592-3N for qemu-devel@nongnu.org; Fri, 03 Feb 2023 09:29:56 -0500 Received: by mail-wm1-x335.google.com with SMTP id d4-20020a05600c3ac400b003db1de2aef0so4003100wms.2 for ; Fri, 03 Feb 2023 06:29:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=K2xxnob3/roFGLD087p6MyGRfXODxkAp5LJkBKCgYJQ=; b=PisbtmTPlprY7uJgKO9dr130HwaV6I0k/581DvL/Ur1rRt1o9kX0WtKcKRfLAiO9dB uz+lDZtKar+gY/3EI8nmSVEg/mTvcOWTS0My/OMBsOhV5wwA2gKHsUBdPuwbLPqBwV1T mOybnQZwg+ZKNLK3pDud/yJHjw5WAiVBVvU4+NpyZBXEA/GHKM7bU/7JmlQcDhXr1Dsp 9pdS/fjYfr/9wxyAwBAVLu4ppPSPluAK8KJvgHtJg6M72j5+jQNpAZqj85bJzw6Na1Ua uSzodVHKnEMqfNWKiuK/TTTtFgX+NcrlH8YuXTpJswZiSIRB82FdYTqvOKo2UgJIzcTT o6Ww== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=K2xxnob3/roFGLD087p6MyGRfXODxkAp5LJkBKCgYJQ=; b=qsvlPlzjAL/BJKFwnJjsWqRdpUW1ZiVYSHZYXUIeA2YbSdmq+Xcc2jNL7W0+eQxDWY 1OWB3TqMAdf+ejY6+H39rGQTTvvzqGc09tIj8khfy6PpLBM4i0rC7jxoL1T7r19TGbpD 2KqPaCDeA3oMAXuaK1/Dpzyweo78na3swYlPWfqEm9R38GKxoxyfRIoT52Jul3bQmP2m Lr+dqfAAFs0CTFkQa03uDXIoE3WcYEKqnfYSZFRsk4eadQisdO1lt8PyaG+je1nG8OyN 6Q0xTQtnYUGMVN+71fPBq/OUpJrf4Xn5jSYsTgnCXOtmUfszuz4FtxkgioBXVSiAC9Sg kCGA== X-Gm-Message-State: AO0yUKWDbkEQHv7h7bL4eMMJOKAFGTqPeQPf3/8QjhDBJ0NnkT82L5AL sLk3BCjwahOUIN7N2KDN3L0Gn3vQt5tuOgos X-Received: by 2002:a05:600c:4e4e:b0:3dd:e621:d328 with SMTP id e14-20020a05600c4e4e00b003dde621d328mr12317510wmq.8.1675434593694; Fri, 03 Feb 2023 06:29:53 -0800 (PST) Received: from orth.archaic.org.uk (orth.archaic.org.uk. [2001:8b0:1d0::2]) by smtp.gmail.com with ESMTPSA id j14-20020a05600c130e00b003df241f52e8sm2578492wmf.42.2023.02.03.06.29.52 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 03 Feb 2023 06:29:53 -0800 (PST) From: Peter Maydell To: qemu-devel@nongnu.org Subject: [PULL 29/33] target/arm: Mark up sysregs for HFGITR bits 48..63 Date: Fri, 3 Feb 2023 14:29:23 +0000 Message-Id: <20230203142927.834793-30-peter.maydell@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230203142927.834793-1-peter.maydell@linaro.org> References: <20230203142927.834793-1-peter.maydell@linaro.org> MIME-Version: 1.0 Received-SPF: pass client-ip=2a00:1450:4864:20::335; envelope-from=peter.maydell@linaro.org; helo=mail-wm1-x335.google.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 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_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 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+patch=linaro.org@nongnu.org Sender: qemu-devel-bounces+patch=linaro.org@nongnu.org Mark up the sysreg definitions for the system instructions trapped by HFGITR bits 48..63. Some of these bits are for trapping instructions which are not in the system instruction encoding (i.e. which are not handled by the ARMCPRegInfo mechanism): * ERET, ERETAA, ERETAB * SVC We will have to handle those separately and manually. Signed-off-by: Peter Maydell Reviewed-by: Richard Henderson Tested-by: Fuad Tabba Message-id: 20230130182459.3309057-20-peter.maydell@linaro.org Message-id: 20230127175507.2895013-20-peter.maydell@linaro.org --- target/arm/cpregs.h | 4 ++++ target/arm/helper.c | 9 +++++++++ 2 files changed, 13 insertions(+) diff --git a/target/arm/cpregs.h b/target/arm/cpregs.h index 2e5ac6b4f98..efcf9181b97 100644 --- a/target/arm/cpregs.h +++ b/target/arm/cpregs.h @@ -696,6 +696,10 @@ typedef enum FGTBit { DO_BIT(HFGITR, TLBIVAAE1), DO_BIT(HFGITR, TLBIVALE1), DO_BIT(HFGITR, TLBIVAALE1), + DO_BIT(HFGITR, CFPRCTX), + DO_BIT(HFGITR, DVPRCTX), + DO_BIT(HFGITR, CPPRCTX), + DO_BIT(HFGITR, DCCVAC), } FGTBit; #undef DO_BIT diff --git a/target/arm/helper.c b/target/arm/helper.c index 5b9cc087e28..c0403aadae2 100644 --- a/target/arm/helper.c +++ b/target/arm/helper.c @@ -5295,6 +5295,7 @@ static const ARMCPRegInfo v8_cp_reginfo[] = { { .name = "DC_CVAC", .state = ARM_CP_STATE_AA64, .opc0 = 1, .opc1 = 3, .crn = 7, .crm = 10, .opc2 = 1, .access = PL0_W, .type = ARM_CP_NOP, + .fgt = FGT_DCCVAC, .accessfn = aa64_cacheop_poc_access }, { .name = "DC_CSW", .state = ARM_CP_STATE_AA64, .opc0 = 1, .opc1 = 0, .crn = 7, .crm = 10, .opc2 = 2, @@ -7588,10 +7589,12 @@ static const ARMCPRegInfo mte_el0_cacheop_reginfo[] = { { .name = "DC_CGVAC", .state = ARM_CP_STATE_AA64, .opc0 = 1, .opc1 = 3, .crn = 7, .crm = 10, .opc2 = 3, .type = ARM_CP_NOP, .access = PL0_W, + .fgt = FGT_DCCVAC, .accessfn = aa64_cacheop_poc_access }, { .name = "DC_CGDVAC", .state = ARM_CP_STATE_AA64, .opc0 = 1, .opc1 = 3, .crn = 7, .crm = 10, .opc2 = 5, .type = ARM_CP_NOP, .access = PL0_W, + .fgt = FGT_DCCVAC, .accessfn = aa64_cacheop_poc_access }, { .name = "DC_CGVAP", .state = ARM_CP_STATE_AA64, .opc0 = 1, .opc1 = 3, .crn = 7, .crm = 12, .opc2 = 3, @@ -7747,24 +7750,30 @@ static CPAccessResult access_predinv(CPUARMState *env, const ARMCPRegInfo *ri, static const ARMCPRegInfo predinv_reginfo[] = { { .name = "CFP_RCTX", .state = ARM_CP_STATE_AA64, .opc0 = 1, .opc1 = 3, .crn = 7, .crm = 3, .opc2 = 4, + .fgt = FGT_CFPRCTX, .type = ARM_CP_NOP, .access = PL0_W, .accessfn = access_predinv }, { .name = "DVP_RCTX", .state = ARM_CP_STATE_AA64, .opc0 = 1, .opc1 = 3, .crn = 7, .crm = 3, .opc2 = 5, + .fgt = FGT_DVPRCTX, .type = ARM_CP_NOP, .access = PL0_W, .accessfn = access_predinv }, { .name = "CPP_RCTX", .state = ARM_CP_STATE_AA64, .opc0 = 1, .opc1 = 3, .crn = 7, .crm = 3, .opc2 = 7, + .fgt = FGT_CPPRCTX, .type = ARM_CP_NOP, .access = PL0_W, .accessfn = access_predinv }, /* * Note the AArch32 opcodes have a different OPC1. */ { .name = "CFPRCTX", .state = ARM_CP_STATE_AA32, .cp = 15, .opc1 = 0, .crn = 7, .crm = 3, .opc2 = 4, + .fgt = FGT_CFPRCTX, .type = ARM_CP_NOP, .access = PL0_W, .accessfn = access_predinv }, { .name = "DVPRCTX", .state = ARM_CP_STATE_AA32, .cp = 15, .opc1 = 0, .crn = 7, .crm = 3, .opc2 = 5, + .fgt = FGT_DVPRCTX, .type = ARM_CP_NOP, .access = PL0_W, .accessfn = access_predinv }, { .name = "CPPRCTX", .state = ARM_CP_STATE_AA32, .cp = 15, .opc1 = 0, .crn = 7, .crm = 3, .opc2 = 7, + .fgt = FGT_CPPRCTX, .type = ARM_CP_NOP, .access = PL0_W, .accessfn = access_predinv }, };