pfn_t.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #ifndef _LINUX_PFN_T_H_
  2. #define _LINUX_PFN_T_H_
  3. #include <linux/mm.h>
  4. /*
  5. * PFN_FLAGS_MASK - mask of all the possible valid pfn_t flags
  6. * PFN_SG_CHAIN - pfn is a pointer to the next scatterlist entry
  7. * PFN_SG_LAST - pfn references a page and is the last scatterlist entry
  8. * PFN_DEV - pfn is not covered by system memmap by default
  9. * PFN_MAP - pfn has a dynamic page mapping established by a device driver
  10. */
  11. #define PFN_FLAGS_MASK (((u64) ~PAGE_MASK) << (BITS_PER_LONG_LONG - PAGE_SHIFT))
  12. #define PFN_SG_CHAIN (1ULL << (BITS_PER_LONG_LONG - 1))
  13. #define PFN_SG_LAST (1ULL << (BITS_PER_LONG_LONG - 2))
  14. #define PFN_DEV (1ULL << (BITS_PER_LONG_LONG - 3))
  15. #define PFN_MAP (1ULL << (BITS_PER_LONG_LONG - 4))
  16. static inline pfn_t __pfn_to_pfn_t(unsigned long pfn, u64 flags)
  17. {
  18. pfn_t pfn_t = { .val = pfn | (flags & PFN_FLAGS_MASK), };
  19. return pfn_t;
  20. }
  21. /* a default pfn to pfn_t conversion assumes that @pfn is pfn_valid() */
  22. static inline pfn_t pfn_to_pfn_t(unsigned long pfn)
  23. {
  24. return __pfn_to_pfn_t(pfn, 0);
  25. }
  26. static inline pfn_t phys_to_pfn_t(phys_addr_t addr, u64 flags)
  27. {
  28. return __pfn_to_pfn_t(addr >> PAGE_SHIFT, flags);
  29. }
  30. static inline bool pfn_t_has_page(pfn_t pfn)
  31. {
  32. return (pfn.val & PFN_MAP) == PFN_MAP || (pfn.val & PFN_DEV) == 0;
  33. }
  34. static inline unsigned long pfn_t_to_pfn(pfn_t pfn)
  35. {
  36. return pfn.val & ~PFN_FLAGS_MASK;
  37. }
  38. static inline struct page *pfn_t_to_page(pfn_t pfn)
  39. {
  40. if (pfn_t_has_page(pfn))
  41. return pfn_to_page(pfn_t_to_pfn(pfn));
  42. return NULL;
  43. }
  44. static inline phys_addr_t pfn_t_to_phys(pfn_t pfn)
  45. {
  46. return PFN_PHYS(pfn_t_to_pfn(pfn));
  47. }
  48. static inline void *pfn_t_to_virt(pfn_t pfn)
  49. {
  50. if (pfn_t_has_page(pfn))
  51. return __va(pfn_t_to_phys(pfn));
  52. return NULL;
  53. }
  54. static inline pfn_t page_to_pfn_t(struct page *page)
  55. {
  56. return pfn_to_pfn_t(page_to_pfn(page));
  57. }
  58. static inline int pfn_t_valid(pfn_t pfn)
  59. {
  60. return pfn_valid(pfn_t_to_pfn(pfn));
  61. }
  62. #ifdef CONFIG_MMU
  63. static inline pte_t pfn_t_pte(pfn_t pfn, pgprot_t pgprot)
  64. {
  65. return pfn_pte(pfn_t_to_pfn(pfn), pgprot);
  66. }
  67. #endif
  68. #ifdef CONFIG_TRANSPARENT_HUGEPAGE
  69. static inline pmd_t pfn_t_pmd(pfn_t pfn, pgprot_t pgprot)
  70. {
  71. return pfn_pmd(pfn_t_to_pfn(pfn), pgprot);
  72. }
  73. #endif
  74. #ifdef __HAVE_ARCH_PTE_DEVMAP
  75. static inline bool pfn_t_devmap(pfn_t pfn)
  76. {
  77. const u64 flags = PFN_DEV|PFN_MAP;
  78. return (pfn.val & flags) == flags;
  79. }
  80. #else
  81. static inline bool pfn_t_devmap(pfn_t pfn)
  82. {
  83. return false;
  84. }
  85. pte_t pte_mkdevmap(pte_t pte);
  86. pmd_t pmd_mkdevmap(pmd_t pmd);
  87. #endif
  88. #endif /* _LINUX_PFN_T_H_ */