hugetlb.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. #ifndef _ASM_SPARC64_HUGETLB_H
  2. #define _ASM_SPARC64_HUGETLB_H
  3. #include <asm/page.h>
  4. void set_huge_pte_at(struct mm_struct *mm, unsigned long addr,
  5. pte_t *ptep, pte_t pte);
  6. pte_t huge_ptep_get_and_clear(struct mm_struct *mm, unsigned long addr,
  7. pte_t *ptep);
  8. static inline void hugetlb_prefault_arch_hook(struct mm_struct *mm)
  9. {
  10. hugetlb_setup(mm);
  11. }
  12. static inline int is_hugepage_only_range(struct mm_struct *mm,
  13. unsigned long addr,
  14. unsigned long len) {
  15. return 0;
  16. }
  17. /*
  18. * If the arch doesn't supply something else, assume that hugepage
  19. * size aligned regions are ok without further preparation.
  20. */
  21. static inline int prepare_hugepage_range(struct file *file,
  22. unsigned long addr, unsigned long len)
  23. {
  24. if (len & ~HPAGE_MASK)
  25. return -EINVAL;
  26. if (addr & ~HPAGE_MASK)
  27. return -EINVAL;
  28. return 0;
  29. }
  30. static inline void hugetlb_free_pgd_range(struct mmu_gather *tlb,
  31. unsigned long addr, unsigned long end,
  32. unsigned long floor,
  33. unsigned long ceiling)
  34. {
  35. free_pgd_range(tlb, addr, end, floor, ceiling);
  36. }
  37. static inline void huge_ptep_clear_flush(struct vm_area_struct *vma,
  38. unsigned long addr, pte_t *ptep)
  39. {
  40. }
  41. static inline int huge_pte_none(pte_t pte)
  42. {
  43. return pte_none(pte);
  44. }
  45. static inline pte_t huge_pte_wrprotect(pte_t pte)
  46. {
  47. return pte_wrprotect(pte);
  48. }
  49. static inline void huge_ptep_set_wrprotect(struct mm_struct *mm,
  50. unsigned long addr, pte_t *ptep)
  51. {
  52. ptep_set_wrprotect(mm, addr, ptep);
  53. }
  54. static inline int huge_ptep_set_access_flags(struct vm_area_struct *vma,
  55. unsigned long addr, pte_t *ptep,
  56. pte_t pte, int dirty)
  57. {
  58. return ptep_set_access_flags(vma, addr, ptep, pte, dirty);
  59. }
  60. static inline pte_t huge_ptep_get(pte_t *ptep)
  61. {
  62. return *ptep;
  63. }
  64. static inline int arch_prepare_hugepage(struct page *page)
  65. {
  66. return 0;
  67. }
  68. static inline void arch_release_hugepage(struct page *page)
  69. {
  70. }
  71. static inline void arch_clear_hugepage_flags(struct page *page)
  72. {
  73. }
  74. #endif /* _ASM_SPARC64_HUGETLB_H */