KVM: ppc: Add kvmppc_mmu_dtlb/itlb_miss for booke
When itlb or dtlb miss happens, E500 needs to update some mmu registers. So that the auto-load mechanism can work on E500 when write a tlb entry. Signed-off-by: Liu Yu <yu.liu@freescale.com> Signed-off-by: Hollis Blanchard <hollisb@us.ibm.com> Signed-off-by: Avi Kivity <avi@redhat.com>
This commit is contained in:
parent
bc8080cbcc
commit
b52a638c39
3 changed files with 12 additions and 0 deletions
|
@ -63,6 +63,8 @@ extern int kvmppc_mmu_dtlb_index(struct kvm_vcpu *vcpu, gva_t eaddr);
|
||||||
extern int kvmppc_mmu_itlb_index(struct kvm_vcpu *vcpu, gva_t eaddr);
|
extern int kvmppc_mmu_itlb_index(struct kvm_vcpu *vcpu, gva_t eaddr);
|
||||||
extern gpa_t kvmppc_mmu_xlate(struct kvm_vcpu *vcpu, unsigned int gtlb_index,
|
extern gpa_t kvmppc_mmu_xlate(struct kvm_vcpu *vcpu, unsigned int gtlb_index,
|
||||||
gva_t eaddr);
|
gva_t eaddr);
|
||||||
|
extern void kvmppc_mmu_dtlb_miss(struct kvm_vcpu *vcpu);
|
||||||
|
extern void kvmppc_mmu_itlb_miss(struct kvm_vcpu *vcpu);
|
||||||
|
|
||||||
extern struct kvm_vcpu *kvmppc_core_vcpu_create(struct kvm *kvm,
|
extern struct kvm_vcpu *kvmppc_core_vcpu_create(struct kvm *kvm,
|
||||||
unsigned int id);
|
unsigned int id);
|
||||||
|
|
|
@ -232,6 +232,14 @@ int kvmppc_mmu_dtlb_index(struct kvm_vcpu *vcpu, gva_t eaddr)
|
||||||
return kvmppc_44x_tlb_index(vcpu, eaddr, vcpu->arch.pid, as);
|
return kvmppc_44x_tlb_index(vcpu, eaddr, vcpu->arch.pid, as);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void kvmppc_mmu_itlb_miss(struct kvm_vcpu *vcpu)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void kvmppc_mmu_dtlb_miss(struct kvm_vcpu *vcpu)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
static void kvmppc_44x_shadow_release(struct kvmppc_vcpu_44x *vcpu_44x,
|
static void kvmppc_44x_shadow_release(struct kvmppc_vcpu_44x *vcpu_44x,
|
||||||
unsigned int stlb_index)
|
unsigned int stlb_index)
|
||||||
{
|
{
|
||||||
|
|
|
@ -295,6 +295,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
|
||||||
kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_DTLB_MISS);
|
kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_DTLB_MISS);
|
||||||
vcpu->arch.dear = vcpu->arch.fault_dear;
|
vcpu->arch.dear = vcpu->arch.fault_dear;
|
||||||
vcpu->arch.esr = vcpu->arch.fault_esr;
|
vcpu->arch.esr = vcpu->arch.fault_esr;
|
||||||
|
kvmppc_mmu_dtlb_miss(vcpu);
|
||||||
kvmppc_account_exit(vcpu, DTLB_REAL_MISS_EXITS);
|
kvmppc_account_exit(vcpu, DTLB_REAL_MISS_EXITS);
|
||||||
r = RESUME_GUEST;
|
r = RESUME_GUEST;
|
||||||
break;
|
break;
|
||||||
|
@ -337,6 +338,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
|
||||||
if (gtlb_index < 0) {
|
if (gtlb_index < 0) {
|
||||||
/* The guest didn't have a mapping for it. */
|
/* The guest didn't have a mapping for it. */
|
||||||
kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_ITLB_MISS);
|
kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_ITLB_MISS);
|
||||||
|
kvmppc_mmu_itlb_miss(vcpu);
|
||||||
kvmppc_account_exit(vcpu, ITLB_REAL_MISS_EXITS);
|
kvmppc_account_exit(vcpu, ITLB_REAL_MISS_EXITS);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue