mmu.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #ifndef _XEN_MMU_H
  2. #include <linux/linkage.h>
  3. #include <asm/page.h>
  4. enum pt_level {
  5. PT_PGD,
  6. PT_PUD,
  7. PT_PMD,
  8. PT_PTE
  9. };
  10. void set_pte_mfn(unsigned long vaddr, unsigned long pfn, pgprot_t flags);
  11. void xen_activate_mm(struct mm_struct *prev, struct mm_struct *next);
  12. void xen_dup_mmap(struct mm_struct *oldmm, struct mm_struct *mm);
  13. void xen_exit_mmap(struct mm_struct *mm);
  14. pteval_t xen_pte_val(pte_t);
  15. pmdval_t xen_pmd_val(pmd_t);
  16. pgdval_t xen_pgd_val(pgd_t);
  17. pte_t xen_make_pte(pteval_t);
  18. pmd_t xen_make_pmd(pmdval_t);
  19. pgd_t xen_make_pgd(pgdval_t);
  20. void xen_set_pte(pte_t *ptep, pte_t pteval);
  21. void xen_set_pte_at(struct mm_struct *mm, unsigned long addr,
  22. pte_t *ptep, pte_t pteval);
  23. #ifdef CONFIG_X86_PAE
  24. void xen_set_pte_atomic(pte_t *ptep, pte_t pte);
  25. void xen_pte_clear(struct mm_struct *mm, unsigned long addr, pte_t *ptep);
  26. void xen_pmd_clear(pmd_t *pmdp);
  27. #endif /* CONFIG_X86_PAE */
  28. void xen_set_pmd(pmd_t *pmdp, pmd_t pmdval);
  29. void xen_set_pud(pud_t *ptr, pud_t val);
  30. void xen_set_pmd_hyper(pmd_t *pmdp, pmd_t pmdval);
  31. void xen_set_pud_hyper(pud_t *ptr, pud_t val);
  32. #if PAGETABLE_LEVELS == 4
  33. pudval_t xen_pud_val(pud_t pud);
  34. pud_t xen_make_pud(pudval_t pudval);
  35. void xen_set_pgd(pgd_t *pgdp, pgd_t pgd);
  36. void xen_set_pgd_hyper(pgd_t *pgdp, pgd_t pgd);
  37. #endif
  38. pgd_t *xen_get_user_pgd(pgd_t *pgd);
  39. pte_t xen_ptep_modify_prot_start(struct mm_struct *mm, unsigned long addr, pte_t *ptep);
  40. void xen_ptep_modify_prot_commit(struct mm_struct *mm, unsigned long addr,
  41. pte_t *ptep, pte_t pte);
  42. unsigned long xen_read_cr2_direct(void);
  43. extern const struct pv_mmu_ops xen_mmu_ops;
  44. #endif /* _XEN_MMU_H */