|
@@ -269,15 +269,19 @@ void kvmppc_mmu_destroy(struct kvm_vcpu *vcpu)
|
|
* Caller must ensure that the specified guest TLB entry is safe to insert into
|
|
* Caller must ensure that the specified guest TLB entry is safe to insert into
|
|
* the shadow TLB.
|
|
* the shadow TLB.
|
|
*/
|
|
*/
|
|
-void kvmppc_mmu_map(struct kvm_vcpu *vcpu, u64 gvaddr, gpa_t gpaddr, u64 asid,
|
|
|
|
- u32 flags, u32 max_bytes, unsigned int gtlb_index)
|
|
|
|
|
|
+void kvmppc_mmu_map(struct kvm_vcpu *vcpu, u64 gvaddr, gpa_t gpaddr,
|
|
|
|
+ unsigned int gtlb_index)
|
|
{
|
|
{
|
|
struct kvmppc_44x_tlbe stlbe;
|
|
struct kvmppc_44x_tlbe stlbe;
|
|
struct kvmppc_vcpu_44x *vcpu_44x = to_44x(vcpu);
|
|
struct kvmppc_vcpu_44x *vcpu_44x = to_44x(vcpu);
|
|
|
|
+ struct kvmppc_44x_tlbe *gtlbe = &vcpu_44x->guest_tlb[gtlb_index];
|
|
struct kvmppc_44x_shadow_ref *ref;
|
|
struct kvmppc_44x_shadow_ref *ref;
|
|
struct page *new_page;
|
|
struct page *new_page;
|
|
hpa_t hpaddr;
|
|
hpa_t hpaddr;
|
|
gfn_t gfn;
|
|
gfn_t gfn;
|
|
|
|
+ u32 asid = gtlbe->tid;
|
|
|
|
+ u32 flags = gtlbe->word2;
|
|
|
|
+ u32 max_bytes = get_tlb_bytes(gtlbe);
|
|
unsigned int victim;
|
|
unsigned int victim;
|
|
|
|
|
|
/* Select TLB entry to clobber. Indirectly guard against races with the TLB
|
|
/* Select TLB entry to clobber. Indirectly guard against races with the TLB
|
|
@@ -448,10 +452,8 @@ int kvmppc_44x_emul_tlbwe(struct kvm_vcpu *vcpu, u8 ra, u8 rs, u8 ws)
|
|
}
|
|
}
|
|
|
|
|
|
if (tlbe_is_host_safe(vcpu, tlbe)) {
|
|
if (tlbe_is_host_safe(vcpu, tlbe)) {
|
|
- u64 asid;
|
|
|
|
gva_t eaddr;
|
|
gva_t eaddr;
|
|
gpa_t gpaddr;
|
|
gpa_t gpaddr;
|
|
- u32 flags;
|
|
|
|
u32 bytes;
|
|
u32 bytes;
|
|
|
|
|
|
eaddr = get_tlb_eaddr(tlbe);
|
|
eaddr = get_tlb_eaddr(tlbe);
|
|
@@ -462,10 +464,7 @@ int kvmppc_44x_emul_tlbwe(struct kvm_vcpu *vcpu, u8 ra, u8 rs, u8 ws)
|
|
eaddr &= ~(bytes - 1);
|
|
eaddr &= ~(bytes - 1);
|
|
gpaddr &= ~(bytes - 1);
|
|
gpaddr &= ~(bytes - 1);
|
|
|
|
|
|
- asid = (tlbe->word0 & PPC44x_TLB_TS) | tlbe->tid;
|
|
|
|
- flags = tlbe->word2 & 0xffff;
|
|
|
|
-
|
|
|
|
- kvmppc_mmu_map(vcpu, eaddr, gpaddr, asid, flags, bytes, gtlb_index);
|
|
|
|
|
|
+ kvmppc_mmu_map(vcpu, eaddr, gpaddr, gtlb_index);
|
|
}
|
|
}
|
|
|
|
|
|
KVMTRACE_5D(GTLB_WRITE, vcpu, gtlb_index, tlbe->tid, tlbe->word0,
|
|
KVMTRACE_5D(GTLB_WRITE, vcpu, gtlb_index, tlbe->tid, tlbe->word0,
|