diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2014-09-27 05:03:33 -0400 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2014-09-27 05:03:33 -0400 |
commit | e77d99d4a4ec761ad061f1ec890c71040a92efe3 (patch) | |
tree | aea6fe2ee5bb6e699045a3629b48208f3e2a26b6 /arch/arm/include | |
parent | bb0ca6acd466af55c95b7ce508f29e23a24cabd9 (diff) | |
parent | 0496daa5cf99741ce8db82686b4c7446a37feabb (diff) |
Merge tag 'kvm-arm-for-3.18' of git://git.kernel.org/pub/scm/linux/kernel/git/kvmarm/kvmarm into kvm-next
Changes for KVM for arm/arm64 for 3.18
This includes a bunch of changes:
- Support read-only memory slots on arm/arm64
- Various changes to fix Sparse warnings
- Correctly detect write vs. read Stage-2 faults
- Various VGIC cleanups and fixes
- Dynamic VGIC data strcuture sizing
- Fix SGI set_clear_pend offset bug
- Fix VTTBR_BADDR Mask
- Correctly report the FSC on Stage-2 faults
Conflicts:
virt/kvm/eventfd.c
[duplicate, different patch where the kvm-arm version broke x86.
The kvm tree instead has the right one]
Diffstat (limited to 'arch/arm/include')
-rw-r--r-- | arch/arm/include/asm/kvm_emulate.h | 5 | ||||
-rw-r--r-- | arch/arm/include/asm/kvm_host.h | 2 | ||||
-rw-r--r-- | arch/arm/include/asm/kvm_mmu.h | 11 | ||||
-rw-r--r-- | arch/arm/include/uapi/asm/kvm.h | 2 |
4 files changed, 8 insertions, 12 deletions
diff --git a/arch/arm/include/asm/kvm_emulate.h b/arch/arm/include/asm/kvm_emulate.h index 69b746955fca..b9db269c6e61 100644 --- a/arch/arm/include/asm/kvm_emulate.h +++ b/arch/arm/include/asm/kvm_emulate.h | |||
@@ -149,6 +149,11 @@ static inline bool kvm_vcpu_trap_is_iabt(struct kvm_vcpu *vcpu) | |||
149 | 149 | ||
150 | static inline u8 kvm_vcpu_trap_get_fault(struct kvm_vcpu *vcpu) | 150 | static inline u8 kvm_vcpu_trap_get_fault(struct kvm_vcpu *vcpu) |
151 | { | 151 | { |
152 | return kvm_vcpu_get_hsr(vcpu) & HSR_FSC; | ||
153 | } | ||
154 | |||
155 | static inline u8 kvm_vcpu_trap_get_fault_type(struct kvm_vcpu *vcpu) | ||
156 | { | ||
152 | return kvm_vcpu_get_hsr(vcpu) & HSR_FSC_TYPE; | 157 | return kvm_vcpu_get_hsr(vcpu) & HSR_FSC_TYPE; |
153 | } | 158 | } |
154 | 159 | ||
diff --git a/arch/arm/include/asm/kvm_host.h b/arch/arm/include/asm/kvm_host.h index 155497c2b4da..53036e21756b 100644 --- a/arch/arm/include/asm/kvm_host.h +++ b/arch/arm/include/asm/kvm_host.h | |||
@@ -43,7 +43,7 @@ | |||
43 | #include <kvm/arm_vgic.h> | 43 | #include <kvm/arm_vgic.h> |
44 | 44 | ||
45 | u32 *kvm_vcpu_reg(struct kvm_vcpu *vcpu, u8 reg_num, u32 mode); | 45 | u32 *kvm_vcpu_reg(struct kvm_vcpu *vcpu, u8 reg_num, u32 mode); |
46 | int kvm_target_cpu(void); | 46 | int __attribute_const__ kvm_target_cpu(void); |
47 | int kvm_reset_vcpu(struct kvm_vcpu *vcpu); | 47 | int kvm_reset_vcpu(struct kvm_vcpu *vcpu); |
48 | void kvm_reset_coprocs(struct kvm_vcpu *vcpu); | 48 | void kvm_reset_coprocs(struct kvm_vcpu *vcpu); |
49 | 49 | ||
diff --git a/arch/arm/include/asm/kvm_mmu.h b/arch/arm/include/asm/kvm_mmu.h index 5cc0b0f5f72f..3f688b458143 100644 --- a/arch/arm/include/asm/kvm_mmu.h +++ b/arch/arm/include/asm/kvm_mmu.h | |||
@@ -78,17 +78,6 @@ static inline void kvm_set_pte(pte_t *pte, pte_t new_pte) | |||
78 | flush_pmd_entry(pte); | 78 | flush_pmd_entry(pte); |
79 | } | 79 | } |
80 | 80 | ||
81 | static inline bool kvm_is_write_fault(unsigned long hsr) | ||
82 | { | ||
83 | unsigned long hsr_ec = hsr >> HSR_EC_SHIFT; | ||
84 | if (hsr_ec == HSR_EC_IABT) | ||
85 | return false; | ||
86 | else if ((hsr & HSR_ISV) && !(hsr & HSR_WNR)) | ||
87 | return false; | ||
88 | else | ||
89 | return true; | ||
90 | } | ||
91 | |||
92 | static inline void kvm_clean_pgd(pgd_t *pgd) | 81 | static inline void kvm_clean_pgd(pgd_t *pgd) |
93 | { | 82 | { |
94 | clean_dcache_area(pgd, PTRS_PER_S2_PGD * sizeof(pgd_t)); | 83 | clean_dcache_area(pgd, PTRS_PER_S2_PGD * sizeof(pgd_t)); |
diff --git a/arch/arm/include/uapi/asm/kvm.h b/arch/arm/include/uapi/asm/kvm.h index e6ebdd3471e5..09ee408c1a67 100644 --- a/arch/arm/include/uapi/asm/kvm.h +++ b/arch/arm/include/uapi/asm/kvm.h | |||
@@ -25,6 +25,7 @@ | |||
25 | 25 | ||
26 | #define __KVM_HAVE_GUEST_DEBUG | 26 | #define __KVM_HAVE_GUEST_DEBUG |
27 | #define __KVM_HAVE_IRQ_LINE | 27 | #define __KVM_HAVE_IRQ_LINE |
28 | #define __KVM_HAVE_READONLY_MEM | ||
28 | 29 | ||
29 | #define KVM_REG_SIZE(id) \ | 30 | #define KVM_REG_SIZE(id) \ |
30 | (1U << (((id) & KVM_REG_SIZE_MASK) >> KVM_REG_SIZE_SHIFT)) | 31 | (1U << (((id) & KVM_REG_SIZE_MASK) >> KVM_REG_SIZE_SHIFT)) |
@@ -173,6 +174,7 @@ struct kvm_arch_memory_slot { | |||
173 | #define KVM_DEV_ARM_VGIC_CPUID_MASK (0xffULL << KVM_DEV_ARM_VGIC_CPUID_SHIFT) | 174 | #define KVM_DEV_ARM_VGIC_CPUID_MASK (0xffULL << KVM_DEV_ARM_VGIC_CPUID_SHIFT) |
174 | #define KVM_DEV_ARM_VGIC_OFFSET_SHIFT 0 | 175 | #define KVM_DEV_ARM_VGIC_OFFSET_SHIFT 0 |
175 | #define KVM_DEV_ARM_VGIC_OFFSET_MASK (0xffffffffULL << KVM_DEV_ARM_VGIC_OFFSET_SHIFT) | 176 | #define KVM_DEV_ARM_VGIC_OFFSET_MASK (0xffffffffULL << KVM_DEV_ARM_VGIC_OFFSET_SHIFT) |
177 | #define KVM_DEV_ARM_VGIC_GRP_NR_IRQS 3 | ||
176 | 178 | ||
177 | /* KVM_IRQ_LINE irq field index values */ | 179 | /* KVM_IRQ_LINE irq field index values */ |
178 | #define KVM_ARM_IRQ_TYPE_SHIFT 24 | 180 | #define KVM_ARM_IRQ_TYPE_SHIFT 24 |