aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/kvm/mmu.c
diff options
context:
space:
mode:
authorAvi Kivity <avi@qumranet.com>2007-12-09 09:15:46 -0500
committerAvi Kivity <avi@qumranet.com>2008-01-30 10:53:20 -0500
commitfe135d2ceb3d7dc08151b3cbad96565d02cc8676 (patch)
tree7dec07ec0a32a53f003551802cb73c4ce3373527 /drivers/kvm/mmu.c
parentb3e4e63fd9ee8cd5d9047b89e0d463d5c48ee5b5 (diff)
KVM: MMU: Simplify calculation of pte access
The nx bit is awkwardly placed in the 63rd bit position; furthermore it has a reversed meaning compared to the other bits, which means we can't use a bitwise and to calculate compounded access masks. So, we simplify things by creating a new 3-bit exec/write/user access word, and doing all calculations in that. Signed-off-by: Avi Kivity <avi@qumranet.com>
Diffstat (limited to 'drivers/kvm/mmu.c')
-rw-r--r--drivers/kvm/mmu.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/drivers/kvm/mmu.c b/drivers/kvm/mmu.c
index 62a74151f847..f8a2137c64a2 100644
--- a/drivers/kvm/mmu.c
+++ b/drivers/kvm/mmu.c
@@ -85,7 +85,8 @@ static int dbg = 1;
85#define PT_PAGE_SIZE_MASK (1ULL << 7) 85#define PT_PAGE_SIZE_MASK (1ULL << 7)
86#define PT_PAT_MASK (1ULL << 7) 86#define PT_PAT_MASK (1ULL << 7)
87#define PT_GLOBAL_MASK (1ULL << 8) 87#define PT_GLOBAL_MASK (1ULL << 8)
88#define PT64_NX_MASK (1ULL << 63) 88#define PT64_NX_SHIFT 63
89#define PT64_NX_MASK (1ULL << PT64_NX_SHIFT)
89 90
90#define PT_PAT_SHIFT 7 91#define PT_PAT_SHIFT 7
91#define PT_DIR_PAT_SHIFT 12 92#define PT_DIR_PAT_SHIFT 12
@@ -153,6 +154,11 @@ static int dbg = 1;
153 154
154#define RMAP_EXT 4 155#define RMAP_EXT 4
155 156
157#define ACC_EXEC_MASK 1
158#define ACC_WRITE_MASK PT_WRITABLE_MASK
159#define ACC_USER_MASK PT_USER_MASK
160#define ACC_ALL (ACC_EXEC_MASK | ACC_WRITE_MASK | ACC_USER_MASK)
161
156struct kvm_rmap_desc { 162struct kvm_rmap_desc {
157 u64 *shadow_ptes[RMAP_EXT]; 163 u64 *shadow_ptes[RMAP_EXT];
158 struct kvm_rmap_desc *more; 164 struct kvm_rmap_desc *more;
@@ -921,7 +927,7 @@ static int nonpaging_map(struct kvm_vcpu *vcpu, gva_t v, struct page *page)
921 >> PAGE_SHIFT; 927 >> PAGE_SHIFT;
922 new_table = kvm_mmu_get_page(vcpu, pseudo_gfn, 928 new_table = kvm_mmu_get_page(vcpu, pseudo_gfn,
923 v, level - 1, 929 v, level - 1,
924 1, 3, &table[index]); 930 1, ACC_ALL, &table[index]);
925 if (!new_table) { 931 if (!new_table) {
926 pgprintk("nonpaging_map: ENOMEM\n"); 932 pgprintk("nonpaging_map: ENOMEM\n");
927 kvm_release_page_clean(page); 933 kvm_release_page_clean(page);
@@ -988,7 +994,7 @@ static void mmu_alloc_roots(struct kvm_vcpu *vcpu)
988 994
989 ASSERT(!VALID_PAGE(root)); 995 ASSERT(!VALID_PAGE(root));
990 sp = kvm_mmu_get_page(vcpu, root_gfn, 0, 996 sp = kvm_mmu_get_page(vcpu, root_gfn, 0,
991 PT64_ROOT_LEVEL, 0, 0, NULL); 997 PT64_ROOT_LEVEL, 0, ACC_ALL, NULL);
992 root = __pa(sp->spt); 998 root = __pa(sp->spt);
993 ++sp->root_count; 999 ++sp->root_count;
994 vcpu->mmu.root_hpa = root; 1000 vcpu->mmu.root_hpa = root;
@@ -1009,7 +1015,7 @@ static void mmu_alloc_roots(struct kvm_vcpu *vcpu)
1009 root_gfn = 0; 1015 root_gfn = 0;
1010 sp = kvm_mmu_get_page(vcpu, root_gfn, i << 30, 1016 sp = kvm_mmu_get_page(vcpu, root_gfn, i << 30,
1011 PT32_ROOT_LEVEL, !is_paging(vcpu), 1017 PT32_ROOT_LEVEL, !is_paging(vcpu),
1012 0, NULL); 1018 ACC_ALL, NULL);
1013 root = __pa(sp->spt); 1019 root = __pa(sp->spt);
1014 ++sp->root_count; 1020 ++sp->root_count;
1015 vcpu->mmu.pae_root[i] = root | PT_PRESENT_MASK; 1021 vcpu->mmu.pae_root[i] = root | PT_PRESENT_MASK;