| From 68cf617309b5f6f3a651165f49f20af1494753ae Mon Sep 17 00:00:00 2001 |
| From: Will Deacon <will@kernel.org> |
| Date: Wed, 8 Jul 2020 17:25:46 +0100 |
| Subject: KVM: arm64: Fix definition of PAGE_HYP_DEVICE |
| |
| From: Will Deacon <will@kernel.org> |
| |
| commit 68cf617309b5f6f3a651165f49f20af1494753ae upstream. |
| |
| PAGE_HYP_DEVICE is intended to encode attribute bits for an EL2 stage-1 |
| pte mapping a device. Unfortunately, it includes PROT_DEVICE_nGnRE which |
| encodes attributes for EL1 stage-1 mappings such as UXN and nG, which are |
| RES0 for EL2, and DBM which is meaningless as TCR_EL2.HD is not set. |
| |
| Fix the definition of PAGE_HYP_DEVICE so that it doesn't set RES0 bits |
| at EL2. |
| |
| Acked-by: Marc Zyngier <maz@kernel.org> |
| Cc: Marc Zyngier <maz@kernel.org> |
| Cc: Catalin Marinas <catalin.marinas@arm.com> |
| Cc: James Morse <james.morse@arm.com> |
| Cc: <stable@vger.kernel.org> |
| Link: https://lore.kernel.org/r/20200708162546.26176-1-will@kernel.org |
| Signed-off-by: Will Deacon <will@kernel.org> |
| Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> |
| |
| --- |
| arch/arm64/include/asm/pgtable-prot.h | 2 +- |
| 1 file changed, 1 insertion(+), 1 deletion(-) |
| |
| --- a/arch/arm64/include/asm/pgtable-prot.h |
| +++ b/arch/arm64/include/asm/pgtable-prot.h |
| @@ -54,7 +54,7 @@ |
| #define PAGE_HYP __pgprot(_HYP_PAGE_DEFAULT | PTE_HYP | PTE_HYP_XN) |
| #define PAGE_HYP_EXEC __pgprot(_HYP_PAGE_DEFAULT | PTE_HYP | PTE_RDONLY) |
| #define PAGE_HYP_RO __pgprot(_HYP_PAGE_DEFAULT | PTE_HYP | PTE_RDONLY | PTE_HYP_XN) |
| -#define PAGE_HYP_DEVICE __pgprot(PROT_DEVICE_nGnRE | PTE_HYP) |
| +#define PAGE_HYP_DEVICE __pgprot(_PROT_DEFAULT | PTE_ATTRINDX(MT_DEVICE_nGnRE) | PTE_HYP | PTE_HYP_XN) |
| |
| #define PAGE_S2_MEMATTR(attr) \ |
| ({ \ |