From: Marc Zyngier <maz@kernel.org>
To: Fuad Tabba <tabba@google.com>
Cc: kernel-team@android.com, kvm@vger.kernel.org,
pbonzini@redhat.com, will@kernel.org,
kvmarm@lists.cs.columbia.edu,
linux-arm-kernel@lists.infradead.org
Subject: Re: [PATCH v4 10/15] KVM: arm64: Add config register bit definitions
Date: Wed, 18 Aug 2021 16:16:04 +0100 [thread overview]
Message-ID: <87h7fmss0b.wl-maz@kernel.org> (raw)
In-Reply-To: <20210817081134.2918285-11-tabba@google.com>
On Tue, 17 Aug 2021 09:11:29 +0100,
Fuad Tabba <tabba@google.com> wrote:
>
> Add hardware configuration register bit definitions for HCR_EL2
> and MDCR_EL2. Future patches toggle these hyp configuration
> register bits to trap on certain accesses.
>
> No functional change intended.
>
> Acked-by: Will Deacon <will@kernel.org>
> Signed-off-by: Fuad Tabba <tabba@google.com>
> ---
> arch/arm64/include/asm/kvm_arm.h | 22 ++++++++++++++++++++++
> 1 file changed, 22 insertions(+)
>
> diff --git a/arch/arm64/include/asm/kvm_arm.h b/arch/arm64/include/asm/kvm_arm.h
> index a928b2dc0b0f..327120c0089f 100644
> --- a/arch/arm64/include/asm/kvm_arm.h
> +++ b/arch/arm64/include/asm/kvm_arm.h
> @@ -12,8 +12,13 @@
> #include <asm/types.h>
>
> /* Hyp Configuration Register (HCR) bits */
> +
> +#define HCR_TID5 (UL(1) << 58)
> +#define HCR_DCT (UL(1) << 57)
> #define HCR_ATA_SHIFT 56
> #define HCR_ATA (UL(1) << HCR_ATA_SHIFT)
> +#define HCR_AMVOFFEN (UL(1) << 51)
> +#define HCR_FIEN (UL(1) << 47)
> #define HCR_FWB (UL(1) << 46)
> #define HCR_API (UL(1) << 41)
> #define HCR_APK (UL(1) << 40)
> @@ -56,6 +61,7 @@
> #define HCR_PTW (UL(1) << 2)
> #define HCR_SWIO (UL(1) << 1)
> #define HCR_VM (UL(1) << 0)
> +#define HCR_RES0 ((UL(1) << 48) | (UL(1) << 39))
>
> /*
> * The bits we set in HCR:
> @@ -277,11 +283,21 @@
> #define CPTR_EL2_TZ (1 << 8)
> #define CPTR_NVHE_EL2_RES1 0x000032ff /* known RES1 bits in CPTR_EL2 (nVHE) */
> #define CPTR_EL2_DEFAULT CPTR_NVHE_EL2_RES1
> +#define CPTR_NVHE_EL2_RES0 (GENMASK(63, 32) | \
> + GENMASK(29, 21) | \
> + GENMASK(19, 14) | \
> + BIT(11))
>
> /* Hyp Debug Configuration Register bits */
> #define MDCR_EL2_E2TB_MASK (UL(0x3))
> #define MDCR_EL2_E2TB_SHIFT (UL(24))
> +#define MDCR_EL2_HPMFZS (UL(1) << 36)
> +#define MDCR_EL2_HPMFZO (UL(1) << 29)
> +#define MDCR_EL2_MTPME (UL(1) << 28)
> +#define MDCR_EL2_TDCC (UL(1) << 27)
> +#define MDCR_EL2_HCCD (UL(1) << 23)
Nit: If you're aiming for completeness, you're missing MDCR_EL2.HLP
(bit 26).
> #define MDCR_EL2_TTRF (UL(1) << 19)
> +#define MDCR_EL2_HPMD (UL(1) << 17)
> #define MDCR_EL2_TPMS (UL(1) << 14)
> #define MDCR_EL2_E2PB_MASK (UL(0x3))
> #define MDCR_EL2_E2PB_SHIFT (UL(12))
> @@ -293,6 +309,12 @@
> #define MDCR_EL2_TPM (UL(1) << 6)
> #define MDCR_EL2_TPMCR (UL(1) << 5)
> #define MDCR_EL2_HPMN_MASK (UL(0x1F))
> +#define MDCR_EL2_RES0 (GENMASK(63, 37) | \
> + GENMASK(35, 30) | \
> + GENMASK(25, 24) | \
> + GENMASK(22, 20) | \
> + BIT(18) | \
> + GENMASK(16, 15))
>
> /* For compatibility with fault code shared with 32-bit */
> #define FSC_FAULT ESR_ELx_FSC_FAULT
Thanks,
M.
--
Without deviation from the norm, progress is not possible.
_______________________________________________
kvmarm mailing list
kvmarm@lists.cs.columbia.edu
https://lists.cs.columbia.edu/mailman/listinfo/kvmarm
WARNING: multiple messages have this Message-ID (diff)
From: Marc Zyngier <maz@kernel.org>
To: Fuad Tabba <tabba@google.com>
Cc: kvmarm@lists.cs.columbia.edu, will@kernel.org,
james.morse@arm.com, alexandru.elisei@arm.com,
suzuki.poulose@arm.com, mark.rutland@arm.com,
christoffer.dall@arm.com, pbonzini@redhat.com,
drjones@redhat.com, oupton@google.com, qperret@google.com,
kvm@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
kernel-team@android.com
Subject: Re: [PATCH v4 10/15] KVM: arm64: Add config register bit definitions
Date: Wed, 18 Aug 2021 16:16:04 +0100 [thread overview]
Message-ID: <87h7fmss0b.wl-maz@kernel.org> (raw)
In-Reply-To: <20210817081134.2918285-11-tabba@google.com>
On Tue, 17 Aug 2021 09:11:29 +0100,
Fuad Tabba <tabba@google.com> wrote:
>
> Add hardware configuration register bit definitions for HCR_EL2
> and MDCR_EL2. Future patches toggle these hyp configuration
> register bits to trap on certain accesses.
>
> No functional change intended.
>
> Acked-by: Will Deacon <will@kernel.org>
> Signed-off-by: Fuad Tabba <tabba@google.com>
> ---
> arch/arm64/include/asm/kvm_arm.h | 22 ++++++++++++++++++++++
> 1 file changed, 22 insertions(+)
>
> diff --git a/arch/arm64/include/asm/kvm_arm.h b/arch/arm64/include/asm/kvm_arm.h
> index a928b2dc0b0f..327120c0089f 100644
> --- a/arch/arm64/include/asm/kvm_arm.h
> +++ b/arch/arm64/include/asm/kvm_arm.h
> @@ -12,8 +12,13 @@
> #include <asm/types.h>
>
> /* Hyp Configuration Register (HCR) bits */
> +
> +#define HCR_TID5 (UL(1) << 58)
> +#define HCR_DCT (UL(1) << 57)
> #define HCR_ATA_SHIFT 56
> #define HCR_ATA (UL(1) << HCR_ATA_SHIFT)
> +#define HCR_AMVOFFEN (UL(1) << 51)
> +#define HCR_FIEN (UL(1) << 47)
> #define HCR_FWB (UL(1) << 46)
> #define HCR_API (UL(1) << 41)
> #define HCR_APK (UL(1) << 40)
> @@ -56,6 +61,7 @@
> #define HCR_PTW (UL(1) << 2)
> #define HCR_SWIO (UL(1) << 1)
> #define HCR_VM (UL(1) << 0)
> +#define HCR_RES0 ((UL(1) << 48) | (UL(1) << 39))
>
> /*
> * The bits we set in HCR:
> @@ -277,11 +283,21 @@
> #define CPTR_EL2_TZ (1 << 8)
> #define CPTR_NVHE_EL2_RES1 0x000032ff /* known RES1 bits in CPTR_EL2 (nVHE) */
> #define CPTR_EL2_DEFAULT CPTR_NVHE_EL2_RES1
> +#define CPTR_NVHE_EL2_RES0 (GENMASK(63, 32) | \
> + GENMASK(29, 21) | \
> + GENMASK(19, 14) | \
> + BIT(11))
>
> /* Hyp Debug Configuration Register bits */
> #define MDCR_EL2_E2TB_MASK (UL(0x3))
> #define MDCR_EL2_E2TB_SHIFT (UL(24))
> +#define MDCR_EL2_HPMFZS (UL(1) << 36)
> +#define MDCR_EL2_HPMFZO (UL(1) << 29)
> +#define MDCR_EL2_MTPME (UL(1) << 28)
> +#define MDCR_EL2_TDCC (UL(1) << 27)
> +#define MDCR_EL2_HCCD (UL(1) << 23)
Nit: If you're aiming for completeness, you're missing MDCR_EL2.HLP
(bit 26).
> #define MDCR_EL2_TTRF (UL(1) << 19)
> +#define MDCR_EL2_HPMD (UL(1) << 17)
> #define MDCR_EL2_TPMS (UL(1) << 14)
> #define MDCR_EL2_E2PB_MASK (UL(0x3))
> #define MDCR_EL2_E2PB_SHIFT (UL(12))
> @@ -293,6 +309,12 @@
> #define MDCR_EL2_TPM (UL(1) << 6)
> #define MDCR_EL2_TPMCR (UL(1) << 5)
> #define MDCR_EL2_HPMN_MASK (UL(0x1F))
> +#define MDCR_EL2_RES0 (GENMASK(63, 37) | \
> + GENMASK(35, 30) | \
> + GENMASK(25, 24) | \
> + GENMASK(22, 20) | \
> + BIT(18) | \
> + GENMASK(16, 15))
>
> /* For compatibility with fault code shared with 32-bit */
> #define FSC_FAULT ESR_ELx_FSC_FAULT
Thanks,
M.
--
Without deviation from the norm, progress is not possible.
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
WARNING: multiple messages have this Message-ID (diff)
From: Marc Zyngier <maz@kernel.org>
To: Fuad Tabba <tabba@google.com>
Cc: kvmarm@lists.cs.columbia.edu, will@kernel.org,
james.morse@arm.com, alexandru.elisei@arm.com,
suzuki.poulose@arm.com, mark.rutland@arm.com,
christoffer.dall@arm.com, pbonzini@redhat.com,
drjones@redhat.com, oupton@google.com, qperret@google.com,
kvm@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
kernel-team@android.com
Subject: Re: [PATCH v4 10/15] KVM: arm64: Add config register bit definitions
Date: Wed, 18 Aug 2021 16:16:04 +0100 [thread overview]
Message-ID: <87h7fmss0b.wl-maz@kernel.org> (raw)
In-Reply-To: <20210817081134.2918285-11-tabba@google.com>
On Tue, 17 Aug 2021 09:11:29 +0100,
Fuad Tabba <tabba@google.com> wrote:
>
> Add hardware configuration register bit definitions for HCR_EL2
> and MDCR_EL2. Future patches toggle these hyp configuration
> register bits to trap on certain accesses.
>
> No functional change intended.
>
> Acked-by: Will Deacon <will@kernel.org>
> Signed-off-by: Fuad Tabba <tabba@google.com>
> ---
> arch/arm64/include/asm/kvm_arm.h | 22 ++++++++++++++++++++++
> 1 file changed, 22 insertions(+)
>
> diff --git a/arch/arm64/include/asm/kvm_arm.h b/arch/arm64/include/asm/kvm_arm.h
> index a928b2dc0b0f..327120c0089f 100644
> --- a/arch/arm64/include/asm/kvm_arm.h
> +++ b/arch/arm64/include/asm/kvm_arm.h
> @@ -12,8 +12,13 @@
> #include <asm/types.h>
>
> /* Hyp Configuration Register (HCR) bits */
> +
> +#define HCR_TID5 (UL(1) << 58)
> +#define HCR_DCT (UL(1) << 57)
> #define HCR_ATA_SHIFT 56
> #define HCR_ATA (UL(1) << HCR_ATA_SHIFT)
> +#define HCR_AMVOFFEN (UL(1) << 51)
> +#define HCR_FIEN (UL(1) << 47)
> #define HCR_FWB (UL(1) << 46)
> #define HCR_API (UL(1) << 41)
> #define HCR_APK (UL(1) << 40)
> @@ -56,6 +61,7 @@
> #define HCR_PTW (UL(1) << 2)
> #define HCR_SWIO (UL(1) << 1)
> #define HCR_VM (UL(1) << 0)
> +#define HCR_RES0 ((UL(1) << 48) | (UL(1) << 39))
>
> /*
> * The bits we set in HCR:
> @@ -277,11 +283,21 @@
> #define CPTR_EL2_TZ (1 << 8)
> #define CPTR_NVHE_EL2_RES1 0x000032ff /* known RES1 bits in CPTR_EL2 (nVHE) */
> #define CPTR_EL2_DEFAULT CPTR_NVHE_EL2_RES1
> +#define CPTR_NVHE_EL2_RES0 (GENMASK(63, 32) | \
> + GENMASK(29, 21) | \
> + GENMASK(19, 14) | \
> + BIT(11))
>
> /* Hyp Debug Configuration Register bits */
> #define MDCR_EL2_E2TB_MASK (UL(0x3))
> #define MDCR_EL2_E2TB_SHIFT (UL(24))
> +#define MDCR_EL2_HPMFZS (UL(1) << 36)
> +#define MDCR_EL2_HPMFZO (UL(1) << 29)
> +#define MDCR_EL2_MTPME (UL(1) << 28)
> +#define MDCR_EL2_TDCC (UL(1) << 27)
> +#define MDCR_EL2_HCCD (UL(1) << 23)
Nit: If you're aiming for completeness, you're missing MDCR_EL2.HLP
(bit 26).
> #define MDCR_EL2_TTRF (UL(1) << 19)
> +#define MDCR_EL2_HPMD (UL(1) << 17)
> #define MDCR_EL2_TPMS (UL(1) << 14)
> #define MDCR_EL2_E2PB_MASK (UL(0x3))
> #define MDCR_EL2_E2PB_SHIFT (UL(12))
> @@ -293,6 +309,12 @@
> #define MDCR_EL2_TPM (UL(1) << 6)
> #define MDCR_EL2_TPMCR (UL(1) << 5)
> #define MDCR_EL2_HPMN_MASK (UL(0x1F))
> +#define MDCR_EL2_RES0 (GENMASK(63, 37) | \
> + GENMASK(35, 30) | \
> + GENMASK(25, 24) | \
> + GENMASK(22, 20) | \
> + BIT(18) | \
> + GENMASK(16, 15))
>
> /* For compatibility with fault code shared with 32-bit */
> #define FSC_FAULT ESR_ELx_FSC_FAULT
Thanks,
M.
--
Without deviation from the norm, progress is not possible.
next prev parent reply other threads:[~2021-08-18 15:16 UTC|newest]
Thread overview: 98+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-08-17 8:11 [PATCH v4 00/15] KVM: arm64: Fixed features for protected VMs Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` [PATCH v4 01/15] KVM: arm64: placeholder to check if VM is protected Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` [PATCH v4 02/15] KVM: arm64: Remove trailing whitespace in comment Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` [PATCH v4 03/15] KVM: arm64: MDCR_EL2 is a 64-bit register Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-18 14:32 ` Marc Zyngier
2021-08-18 14:32 ` Marc Zyngier
2021-08-18 14:32 ` Marc Zyngier
2021-08-17 8:11 ` [PATCH v4 04/15] KVM: arm64: Fix names of config register fields Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` [PATCH v4 05/15] KVM: arm64: Refactor sys_regs.h,c for nVHE reuse Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` [PATCH v4 06/15] KVM: arm64: Restore mdcr_el2 from vcpu Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-18 13:13 ` Will Deacon
2021-08-18 13:13 ` Will Deacon
2021-08-18 13:13 ` Will Deacon
2021-08-18 14:42 ` Marc Zyngier
2021-08-18 14:42 ` Marc Zyngier
2021-08-18 14:42 ` Marc Zyngier
2021-08-17 8:11 ` [PATCH v4 07/15] KVM: arm64: Keep mdcr_el2's value as set by __init_el2_debug Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-18 13:17 ` Will Deacon
2021-08-18 13:17 ` Will Deacon
2021-08-18 13:17 ` Will Deacon
2021-08-17 8:11 ` [PATCH v4 08/15] KVM: arm64: Track value of cptr_el2 in struct kvm_vcpu_arch Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` [PATCH v4 09/15] KVM: arm64: Add feature register flag definitions Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-18 13:21 ` Will Deacon
2021-08-18 13:21 ` Will Deacon
2021-08-18 13:21 ` Will Deacon
2021-08-17 8:11 ` [PATCH v4 10/15] KVM: arm64: Add config register bit definitions Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-18 15:16 ` Marc Zyngier [this message]
2021-08-18 15:16 ` Marc Zyngier
2021-08-18 15:16 ` Marc Zyngier
2021-08-17 8:11 ` [PATCH v4 11/15] KVM: arm64: Guest exit handlers for nVHE hyp Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 17:11 ` kernel test robot
2021-08-17 17:11 ` kernel test robot
2021-08-18 16:45 ` Marc Zyngier
2021-08-18 16:45 ` Marc Zyngier
2021-08-18 16:45 ` Marc Zyngier
2021-08-19 14:35 ` Marc Zyngier
2021-08-19 14:35 ` Marc Zyngier
2021-08-19 14:35 ` Marc Zyngier
2021-08-23 10:21 ` Fuad Tabba
2021-08-23 10:21 ` Fuad Tabba
2021-08-23 10:21 ` Fuad Tabba
2021-08-23 12:10 ` Marc Zyngier
2021-08-23 12:10 ` Marc Zyngier
2021-08-23 12:10 ` Marc Zyngier
2021-08-17 8:11 ` [PATCH v4 12/15] KVM: arm64: Add trap handlers for protected VMs Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 16:43 ` kernel test robot
2021-08-17 16:43 ` kernel test robot
2021-08-17 18:04 ` kernel test robot
2021-08-17 18:04 ` kernel test robot
2021-08-17 8:11 ` [PATCH v4 13/15] KVM: arm64: Move sanitized copies of CPU features Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` [PATCH v4 14/15] KVM: arm64: Trap access to pVM restricted features Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 21:30 ` kernel test robot
2021-08-17 21:30 ` kernel test robot
2021-08-17 8:11 ` [PATCH v4 15/15] KVM: arm64: Handle protected guests at 32 bits Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-17 8:11 ` Fuad Tabba
2021-08-19 8:10 ` Oliver Upton
2021-08-19 8:10 ` Oliver Upton
2021-08-19 8:10 ` Oliver Upton
2021-08-23 10:25 ` Fuad Tabba
2021-08-23 10:25 ` Fuad Tabba
2021-08-23 10:25 ` Fuad Tabba
2021-08-20 10:34 ` [PATCH v4 00/15] KVM: arm64: Fixed features for protected VMs Marc Zyngier
2021-08-20 10:34 ` Marc Zyngier
2021-08-20 10:34 ` Marc Zyngier
2021-08-23 10:23 ` Fuad Tabba
2021-08-23 10:23 ` Fuad Tabba
2021-08-23 10:23 ` Fuad Tabba
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87h7fmss0b.wl-maz@kernel.org \
--to=maz@kernel.org \
--cc=kernel-team@android.com \
--cc=kvm@vger.kernel.org \
--cc=kvmarm@lists.cs.columbia.edu \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=pbonzini@redhat.com \
--cc=tabba@google.com \
--cc=will@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.