diff options
Diffstat (limited to 'arch/x86/xen')
| -rw-r--r-- | arch/x86/xen/enlighten.c | 12 | ||||
| -rw-r--r-- | arch/x86/xen/mmu.c | 4 | ||||
| -rw-r--r-- | arch/x86/xen/p2m.c | 17 |
3 files changed, 29 insertions, 4 deletions
diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c index a4d7b647867f..201d09a7c46b 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c | |||
| @@ -1473,6 +1473,18 @@ static void xen_pvh_set_cr_flags(int cpu) | |||
| 1473 | * X86_CR0_TS, X86_CR0_PE, X86_CR0_ET are set by Xen for HVM guests | 1473 | * X86_CR0_TS, X86_CR0_PE, X86_CR0_ET are set by Xen for HVM guests |
| 1474 | * (which PVH shared codepaths), while X86_CR0_PG is for PVH. */ | 1474 | * (which PVH shared codepaths), while X86_CR0_PG is for PVH. */ |
| 1475 | write_cr0(read_cr0() | X86_CR0_MP | X86_CR0_NE | X86_CR0_WP | X86_CR0_AM); | 1475 | write_cr0(read_cr0() | X86_CR0_MP | X86_CR0_NE | X86_CR0_WP | X86_CR0_AM); |
| 1476 | |||
| 1477 | if (!cpu) | ||
| 1478 | return; | ||
| 1479 | /* | ||
| 1480 | * For BSP, PSE PGE are set in probe_page_size_mask(), for APs | ||
| 1481 | * set them here. For all, OSFXSR OSXMMEXCPT are set in fpu_init. | ||
| 1482 | */ | ||
| 1483 | if (cpu_has_pse) | ||
| 1484 | set_in_cr4(X86_CR4_PSE); | ||
| 1485 | |||
| 1486 | if (cpu_has_pge) | ||
| 1487 | set_in_cr4(X86_CR4_PGE); | ||
| 1476 | } | 1488 | } |
| 1477 | 1489 | ||
| 1478 | /* | 1490 | /* |
diff --git a/arch/x86/xen/mmu.c b/arch/x86/xen/mmu.c index 2423ef04ffea..256282e7888b 100644 --- a/arch/x86/xen/mmu.c +++ b/arch/x86/xen/mmu.c | |||
| @@ -365,7 +365,7 @@ void xen_ptep_modify_prot_commit(struct mm_struct *mm, unsigned long addr, | |||
| 365 | /* Assume pteval_t is equivalent to all the other *val_t types. */ | 365 | /* Assume pteval_t is equivalent to all the other *val_t types. */ |
| 366 | static pteval_t pte_mfn_to_pfn(pteval_t val) | 366 | static pteval_t pte_mfn_to_pfn(pteval_t val) |
| 367 | { | 367 | { |
| 368 | if (val & _PAGE_PRESENT) { | 368 | if (pteval_present(val)) { |
| 369 | unsigned long mfn = (val & PTE_PFN_MASK) >> PAGE_SHIFT; | 369 | unsigned long mfn = (val & PTE_PFN_MASK) >> PAGE_SHIFT; |
| 370 | unsigned long pfn = mfn_to_pfn(mfn); | 370 | unsigned long pfn = mfn_to_pfn(mfn); |
| 371 | 371 | ||
| @@ -381,7 +381,7 @@ static pteval_t pte_mfn_to_pfn(pteval_t val) | |||
| 381 | 381 | ||
| 382 | static pteval_t pte_pfn_to_mfn(pteval_t val) | 382 | static pteval_t pte_pfn_to_mfn(pteval_t val) |
| 383 | { | 383 | { |
| 384 | if (val & _PAGE_PRESENT) { | 384 | if (pteval_present(val)) { |
| 385 | unsigned long pfn = (val & PTE_PFN_MASK) >> PAGE_SHIFT; | 385 | unsigned long pfn = (val & PTE_PFN_MASK) >> PAGE_SHIFT; |
| 386 | pteval_t flags = val & PTE_FLAGS_MASK; | 386 | pteval_t flags = val & PTE_FLAGS_MASK; |
| 387 | unsigned long mfn; | 387 | unsigned long mfn; |
diff --git a/arch/x86/xen/p2m.c b/arch/x86/xen/p2m.c index 8009acbe41e4..696c694986d0 100644 --- a/arch/x86/xen/p2m.c +++ b/arch/x86/xen/p2m.c | |||
| @@ -899,6 +899,13 @@ int m2p_add_override(unsigned long mfn, struct page *page, | |||
| 899 | "m2p_add_override: pfn %lx not mapped", pfn)) | 899 | "m2p_add_override: pfn %lx not mapped", pfn)) |
| 900 | return -EINVAL; | 900 | return -EINVAL; |
| 901 | } | 901 | } |
| 902 | WARN_ON(PagePrivate(page)); | ||
| 903 | SetPagePrivate(page); | ||
| 904 | set_page_private(page, mfn); | ||
| 905 | page->index = pfn_to_mfn(pfn); | ||
| 906 | |||
| 907 | if (unlikely(!set_phys_to_machine(pfn, FOREIGN_FRAME(mfn)))) | ||
| 908 | return -ENOMEM; | ||
| 902 | 909 | ||
| 903 | if (kmap_op != NULL) { | 910 | if (kmap_op != NULL) { |
| 904 | if (!PageHighMem(page)) { | 911 | if (!PageHighMem(page)) { |
| @@ -937,16 +944,19 @@ int m2p_add_override(unsigned long mfn, struct page *page, | |||
| 937 | } | 944 | } |
| 938 | EXPORT_SYMBOL_GPL(m2p_add_override); | 945 | EXPORT_SYMBOL_GPL(m2p_add_override); |
| 939 | int m2p_remove_override(struct page *page, | 946 | int m2p_remove_override(struct page *page, |
| 940 | struct gnttab_map_grant_ref *kmap_op, | 947 | struct gnttab_map_grant_ref *kmap_op) |
| 941 | unsigned long mfn) | ||
| 942 | { | 948 | { |
| 943 | unsigned long flags; | 949 | unsigned long flags; |
| 950 | unsigned long mfn; | ||
| 944 | unsigned long pfn; | 951 | unsigned long pfn; |
| 945 | unsigned long uninitialized_var(address); | 952 | unsigned long uninitialized_var(address); |
| 946 | unsigned level; | 953 | unsigned level; |
| 947 | pte_t *ptep = NULL; | 954 | pte_t *ptep = NULL; |
| 948 | 955 | ||
| 949 | pfn = page_to_pfn(page); | 956 | pfn = page_to_pfn(page); |
| 957 | mfn = get_phys_to_machine(pfn); | ||
| 958 | if (mfn == INVALID_P2M_ENTRY || !(mfn & FOREIGN_FRAME_BIT)) | ||
| 959 | return -EINVAL; | ||
| 950 | 960 | ||
| 951 | if (!PageHighMem(page)) { | 961 | if (!PageHighMem(page)) { |
| 952 | address = (unsigned long)__va(pfn << PAGE_SHIFT); | 962 | address = (unsigned long)__va(pfn << PAGE_SHIFT); |
| @@ -960,7 +970,10 @@ int m2p_remove_override(struct page *page, | |||
| 960 | spin_lock_irqsave(&m2p_override_lock, flags); | 970 | spin_lock_irqsave(&m2p_override_lock, flags); |
| 961 | list_del(&page->lru); | 971 | list_del(&page->lru); |
| 962 | spin_unlock_irqrestore(&m2p_override_lock, flags); | 972 | spin_unlock_irqrestore(&m2p_override_lock, flags); |
| 973 | WARN_ON(!PagePrivate(page)); | ||
| 974 | ClearPagePrivate(page); | ||
| 963 | 975 | ||
| 976 | set_phys_to_machine(pfn, page->index); | ||
| 964 | if (kmap_op != NULL) { | 977 | if (kmap_op != NULL) { |
| 965 | if (!PageHighMem(page)) { | 978 | if (!PageHighMem(page)) { |
| 966 | struct multicall_space mcs; | 979 | struct multicall_space mcs; |
