diff options
Diffstat (limited to 'arch/powerpc/kvm/e500.h')
| -rw-r--r-- | arch/powerpc/kvm/e500.h | 24 |
1 files changed, 8 insertions, 16 deletions
diff --git a/arch/powerpc/kvm/e500.h b/arch/powerpc/kvm/e500.h index 41cefd43655f..33db48a8ce24 100644 --- a/arch/powerpc/kvm/e500.h +++ b/arch/powerpc/kvm/e500.h | |||
| @@ -26,17 +26,20 @@ | |||
| 26 | #define E500_PID_NUM 3 | 26 | #define E500_PID_NUM 3 |
| 27 | #define E500_TLB_NUM 2 | 27 | #define E500_TLB_NUM 2 |
| 28 | 28 | ||
| 29 | #define E500_TLB_VALID 1 | 29 | /* entry is mapped somewhere in host TLB */ |
| 30 | #define E500_TLB_BITMAP 2 | 30 | #define E500_TLB_VALID (1 << 0) |
| 31 | /* TLB1 entry is mapped by host TLB1, tracked by bitmaps */ | ||
| 32 | #define E500_TLB_BITMAP (1 << 1) | ||
| 33 | /* TLB1 entry is mapped by host TLB0 */ | ||
| 31 | #define E500_TLB_TLB0 (1 << 2) | 34 | #define E500_TLB_TLB0 (1 << 2) |
| 32 | 35 | ||
| 33 | struct tlbe_ref { | 36 | struct tlbe_ref { |
| 34 | pfn_t pfn; | 37 | pfn_t pfn; /* valid only for TLB0, except briefly */ |
| 35 | unsigned int flags; /* E500_TLB_* */ | 38 | unsigned int flags; /* E500_TLB_* */ |
| 36 | }; | 39 | }; |
| 37 | 40 | ||
| 38 | struct tlbe_priv { | 41 | struct tlbe_priv { |
| 39 | struct tlbe_ref ref; /* TLB0 only -- TLB1 uses tlb_refs */ | 42 | struct tlbe_ref ref; |
| 40 | }; | 43 | }; |
| 41 | 44 | ||
| 42 | #ifdef CONFIG_KVM_E500V2 | 45 | #ifdef CONFIG_KVM_E500V2 |
| @@ -63,17 +66,6 @@ struct kvmppc_vcpu_e500 { | |||
| 63 | 66 | ||
| 64 | unsigned int gtlb_nv[E500_TLB_NUM]; | 67 | unsigned int gtlb_nv[E500_TLB_NUM]; |
| 65 | 68 | ||
| 66 | /* | ||
| 67 | * information associated with each host TLB entry -- | ||
| 68 | * TLB1 only for now. If/when guest TLB1 entries can be | ||
| 69 | * mapped with host TLB0, this will be used for that too. | ||
| 70 | * | ||
| 71 | * We don't want to use this for guest TLB0 because then we'd | ||
| 72 | * have the overhead of doing the translation again even if | ||
| 73 | * the entry is still in the guest TLB (e.g. we swapped out | ||
| 74 | * and back, and our host TLB entries got evicted). | ||
| 75 | */ | ||
| 76 | struct tlbe_ref *tlb_refs[E500_TLB_NUM]; | ||
| 77 | unsigned int host_tlb1_nv; | 69 | unsigned int host_tlb1_nv; |
| 78 | 70 | ||
| 79 | u32 svr; | 71 | u32 svr; |
