diff options
-rw-r--r-- | include/asm-x86/paravirt.h | 33 |
1 files changed, 26 insertions, 7 deletions
diff --git a/include/asm-x86/paravirt.h b/include/asm-x86/paravirt.h index eac25b5323a2..3593211e345b 100644 --- a/include/asm-x86/paravirt.h +++ b/include/asm-x86/paravirt.h | |||
@@ -978,18 +978,37 @@ static inline pgdval_t pgd_val(pgd_t pgd) | |||
978 | return ret; | 978 | return ret; |
979 | } | 979 | } |
980 | 980 | ||
981 | #ifdef CONFIG_X86_PAE | 981 | #if PAGETABLE_LEVELS >= 3 |
982 | static inline pmd_t __pmd(unsigned long long val) | 982 | static inline pmd_t __pmd(pmdval_t val) |
983 | { | 983 | { |
984 | return (pmd_t) { PVOP_CALL2(unsigned long long, pv_mmu_ops.make_pmd, | 984 | pmdval_t ret; |
985 | val, val >> 32) }; | 985 | |
986 | if (sizeof(pmdval_t) > sizeof(long)) | ||
987 | ret = PVOP_CALL2(pmdval_t, pv_mmu_ops.make_pmd, | ||
988 | val, (u64)val >> 32); | ||
989 | else | ||
990 | ret = PVOP_CALL1(pmdval_t, pv_mmu_ops.make_pmd, | ||
991 | val); | ||
992 | |||
993 | return (pmd_t) { ret }; | ||
986 | } | 994 | } |
987 | 995 | ||
988 | static inline unsigned long long pmd_val(pmd_t x) | 996 | static inline pmdval_t pmd_val(pmd_t pmd) |
989 | { | 997 | { |
990 | return PVOP_CALL2(unsigned long long, pv_mmu_ops.pmd_val, | 998 | pmdval_t ret; |
991 | x.pmd, x.pmd >> 32); | 999 | |
1000 | if (sizeof(pmdval_t) > sizeof(long)) | ||
1001 | ret = PVOP_CALL2(pmdval_t, pv_mmu_ops.pmd_val, | ||
1002 | pmd.pmd, (u64)pmd.pmd >> 32); | ||
1003 | else | ||
1004 | ret = PVOP_CALL1(pmdval_t, pv_mmu_ops.pmd_val, | ||
1005 | pmd.pmd); | ||
1006 | |||
1007 | return ret; | ||
992 | } | 1008 | } |
1009 | #endif /* PAGETABLE_LEVELS >= 3 */ | ||
1010 | |||
1011 | #ifdef CONFIG_X86_PAE | ||
993 | 1012 | ||
994 | static inline void set_pte(pte_t *ptep, pte_t pteval) | 1013 | static inline void set_pte(pte_t *ptep, pte_t pteval) |
995 | { | 1014 | { |