blob: 98d71659da5a15ceb21a08f090d1c457d52df775 [file] [log] [blame]
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -07001#ifndef _XEN_MMU_H
2
3#include <linux/linkage.h>
4#include <asm/page.h>
5
Mark McLoughlinf6433702008-04-02 15:36:36 +01006enum pt_level {
7 PT_PGD,
8 PT_PUD,
9 PT_PMD,
10 PT_PTE
11};
12
Jeremy Fitzhardingef87e4ca2007-07-17 18:37:06 -070013
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070014void set_pte_mfn(unsigned long vaddr, unsigned long pfn, pgprot_t flags);
15
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070016
17void xen_activate_mm(struct mm_struct *prev, struct mm_struct *next);
18void xen_dup_mmap(struct mm_struct *oldmm, struct mm_struct *mm);
19void xen_exit_mmap(struct mm_struct *mm);
20
Jeremy Fitzhardinge3843fc22008-05-09 12:05:57 +010021pteval_t xen_pte_val(pte_t);
22pmdval_t xen_pmd_val(pmd_t);
23pgdval_t xen_pgd_val(pgd_t);
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070024
Jeremy Fitzhardinge3843fc22008-05-09 12:05:57 +010025pte_t xen_make_pte(pteval_t);
26pmd_t xen_make_pmd(pmdval_t);
27pgd_t xen_make_pgd(pgdval_t);
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070028
Jeremy Fitzhardingee2426cf2008-05-31 01:24:27 +010029void xen_set_pte(pte_t *ptep, pte_t pteval);
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070030void xen_set_pte_at(struct mm_struct *mm, unsigned long addr,
31 pte_t *ptep, pte_t pteval);
Jeremy Fitzhardingef6e58732008-07-08 15:06:38 -070032
33#ifdef CONFIG_X86_PAE
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070034void xen_set_pte_atomic(pte_t *ptep, pte_t pte);
Jeremy Fitzhardingef6e58732008-07-08 15:06:38 -070035void xen_pte_clear(struct mm_struct *mm, unsigned long addr, pte_t *ptep);
36void xen_pmd_clear(pmd_t *pmdp);
37#endif /* CONFIG_X86_PAE */
38
Jeremy Fitzhardingee2426cf2008-05-31 01:24:27 +010039void xen_set_pmd(pmd_t *pmdp, pmd_t pmdval);
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070040void xen_set_pud(pud_t *ptr, pud_t val);
Jeremy Fitzhardingee2426cf2008-05-31 01:24:27 +010041void xen_set_pmd_hyper(pmd_t *pmdp, pmd_t pmdval);
42void xen_set_pud_hyper(pud_t *ptr, pud_t val);
Jeremy Fitzhardingef6e58732008-07-08 15:06:38 -070043
44#if PAGETABLE_LEVELS == 4
45pudval_t xen_pud_val(pud_t pud);
46pud_t xen_make_pud(pudval_t pudval);
47void xen_set_pgd(pgd_t *pgdp, pgd_t pgd);
48void xen_set_pgd_hyper(pgd_t *pgdp, pgd_t pgd);
49#endif
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070050
Jeremy Fitzhardinged6182fb2008-07-08 15:07:13 -070051pgd_t *xen_get_user_pgd(pgd_t *pgd);
52
Jeremy Fitzhardingee57778a2008-06-16 04:30:02 -070053pte_t xen_ptep_modify_prot_start(struct mm_struct *mm, unsigned long addr, pte_t *ptep);
54void xen_ptep_modify_prot_commit(struct mm_struct *mm, unsigned long addr,
55 pte_t *ptep, pte_t pte);
56
Jeremy Fitzhardinge3b827c12007-07-17 18:37:04 -070057#endif /* _XEN_MMU_H */