diff options
Diffstat (limited to 'arch')
| -rw-r--r-- | arch/x86/include/asm/xen/page.h | 5 | ||||
| -rw-r--r-- | arch/x86/xen/p2m.c | 17 |
2 files changed, 5 insertions, 17 deletions
diff --git a/arch/x86/include/asm/xen/page.h b/arch/x86/include/asm/xen/page.h index 3e276eb23d1b..787e1bb5aafc 100644 --- a/arch/x86/include/asm/xen/page.h +++ b/arch/x86/include/asm/xen/page.h | |||
| @@ -52,7 +52,8 @@ extern unsigned long set_phys_range_identity(unsigned long pfn_s, | |||
| 52 | extern int m2p_add_override(unsigned long mfn, struct page *page, | 52 | extern int m2p_add_override(unsigned long mfn, struct page *page, |
| 53 | struct gnttab_map_grant_ref *kmap_op); | 53 | struct gnttab_map_grant_ref *kmap_op); |
| 54 | extern int m2p_remove_override(struct page *page, | 54 | extern int m2p_remove_override(struct page *page, |
| 55 | struct gnttab_map_grant_ref *kmap_op); | 55 | struct gnttab_map_grant_ref *kmap_op, |
| 56 | unsigned long mfn); | ||
| 56 | extern struct page *m2p_find_override(unsigned long mfn); | 57 | extern struct page *m2p_find_override(unsigned long mfn); |
| 57 | extern unsigned long m2p_find_override_pfn(unsigned long mfn, unsigned long pfn); | 58 | extern unsigned long m2p_find_override_pfn(unsigned long mfn, unsigned long pfn); |
| 58 | 59 | ||
| @@ -121,7 +122,7 @@ static inline unsigned long mfn_to_pfn(unsigned long mfn) | |||
| 121 | pfn = m2p_find_override_pfn(mfn, ~0); | 122 | pfn = m2p_find_override_pfn(mfn, ~0); |
| 122 | } | 123 | } |
| 123 | 124 | ||
| 124 | /* | 125 | /* |
| 125 | * pfn is ~0 if there are no entries in the m2p for mfn or if the | 126 | * pfn is ~0 if there are no entries in the m2p for mfn or if the |
| 126 | * entry doesn't map back to the mfn and m2p_override doesn't have a | 127 | * entry doesn't map back to the mfn and m2p_override doesn't have a |
| 127 | * valid entry for it. | 128 | * valid entry for it. |
diff --git a/arch/x86/xen/p2m.c b/arch/x86/xen/p2m.c index 696c694986d0..8009acbe41e4 100644 --- a/arch/x86/xen/p2m.c +++ b/arch/x86/xen/p2m.c | |||
| @@ -899,13 +899,6 @@ 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; | ||
| 909 | 902 | ||
| 910 | if (kmap_op != NULL) { | 903 | if (kmap_op != NULL) { |
| 911 | if (!PageHighMem(page)) { | 904 | if (!PageHighMem(page)) { |
| @@ -944,19 +937,16 @@ int m2p_add_override(unsigned long mfn, struct page *page, | |||
| 944 | } | 937 | } |
| 945 | EXPORT_SYMBOL_GPL(m2p_add_override); | 938 | EXPORT_SYMBOL_GPL(m2p_add_override); |
| 946 | int m2p_remove_override(struct page *page, | 939 | int m2p_remove_override(struct page *page, |
| 947 | struct gnttab_map_grant_ref *kmap_op) | 940 | struct gnttab_map_grant_ref *kmap_op, |
| 941 | unsigned long mfn) | ||
| 948 | { | 942 | { |
| 949 | unsigned long flags; | 943 | unsigned long flags; |
| 950 | unsigned long mfn; | ||
| 951 | unsigned long pfn; | 944 | unsigned long pfn; |
| 952 | unsigned long uninitialized_var(address); | 945 | unsigned long uninitialized_var(address); |
| 953 | unsigned level; | 946 | unsigned level; |
| 954 | pte_t *ptep = NULL; | 947 | pte_t *ptep = NULL; |
| 955 | 948 | ||
| 956 | pfn = page_to_pfn(page); | 949 | 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; | ||
| 960 | 950 | ||
| 961 | if (!PageHighMem(page)) { | 951 | if (!PageHighMem(page)) { |
| 962 | address = (unsigned long)__va(pfn << PAGE_SHIFT); | 952 | address = (unsigned long)__va(pfn << PAGE_SHIFT); |
| @@ -970,10 +960,7 @@ int m2p_remove_override(struct page *page, | |||
| 970 | spin_lock_irqsave(&m2p_override_lock, flags); | 960 | spin_lock_irqsave(&m2p_override_lock, flags); |
| 971 | list_del(&page->lru); | 961 | list_del(&page->lru); |
| 972 | spin_unlock_irqrestore(&m2p_override_lock, flags); | 962 | spin_unlock_irqrestore(&m2p_override_lock, flags); |
| 973 | WARN_ON(!PagePrivate(page)); | ||
| 974 | ClearPagePrivate(page); | ||
| 975 | 963 | ||
| 976 | set_phys_to_machine(pfn, page->index); | ||
| 977 | if (kmap_op != NULL) { | 964 | if (kmap_op != NULL) { |
| 978 | if (!PageHighMem(page)) { | 965 | if (!PageHighMem(page)) { |
| 979 | struct multicall_space mcs; | 966 | struct multicall_space mcs; |
