pageblock-flags.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /*
  2. * Macros for manipulating and testing flags related to a
  3. * pageblock_nr_pages number of pages.
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation version 2 of the License
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program; if not, write to the Free Software
  16. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  17. *
  18. * Copyright (C) IBM Corporation, 2006
  19. *
  20. * Original author, Mel Gorman
  21. * Major cleanups and reduction of bit operations, Andy Whitcroft
  22. */
  23. #ifndef PAGEBLOCK_FLAGS_H
  24. #define PAGEBLOCK_FLAGS_H
  25. #include <linux/types.h>
  26. /* Bit indices that affect a whole block of pages */
  27. enum pageblock_bits {
  28. PB_migrate,
  29. PB_migrate_end = PB_migrate + 3 - 1,
  30. /* 3 bits required for migrate types */
  31. PB_migrate_skip,/* If set the block is skipped by compaction */
  32. /*
  33. * Assume the bits will always align on a word. If this assumption
  34. * changes then get/set pageblock needs updating.
  35. */
  36. NR_PAGEBLOCK_BITS
  37. };
  38. #ifdef CONFIG_HUGETLB_PAGE
  39. #ifdef CONFIG_HUGETLB_PAGE_SIZE_VARIABLE
  40. /* Huge page sizes are variable */
  41. extern unsigned int pageblock_order;
  42. #else /* CONFIG_HUGETLB_PAGE_SIZE_VARIABLE */
  43. /* Huge pages are a constant size */
  44. #define pageblock_order HUGETLB_PAGE_ORDER
  45. #endif /* CONFIG_HUGETLB_PAGE_SIZE_VARIABLE */
  46. #else /* CONFIG_HUGETLB_PAGE */
  47. /* If huge pages are not used, group by MAX_ORDER_NR_PAGES */
  48. #define pageblock_order (MAX_ORDER-1)
  49. #endif /* CONFIG_HUGETLB_PAGE */
  50. #define pageblock_nr_pages (1UL << pageblock_order)
  51. /* Forward declaration */
  52. struct page;
  53. unsigned long get_pfnblock_flags_mask(struct page *page,
  54. unsigned long pfn,
  55. unsigned long end_bitidx,
  56. unsigned long mask);
  57. void set_pfnblock_flags_mask(struct page *page,
  58. unsigned long flags,
  59. unsigned long pfn,
  60. unsigned long end_bitidx,
  61. unsigned long mask);
  62. /* Declarations for getting and setting flags. See mm/page_alloc.c */
  63. #define get_pageblock_flags_group(page, start_bitidx, end_bitidx) \
  64. get_pfnblock_flags_mask(page, page_to_pfn(page), \
  65. end_bitidx, \
  66. (1 << (end_bitidx - start_bitidx + 1)) - 1)
  67. #define set_pageblock_flags_group(page, flags, start_bitidx, end_bitidx) \
  68. set_pfnblock_flags_mask(page, flags, page_to_pfn(page), \
  69. end_bitidx, \
  70. (1 << (end_bitidx - start_bitidx + 1)) - 1)
  71. #ifdef CONFIG_COMPACTION
  72. #define get_pageblock_skip(page) \
  73. get_pageblock_flags_group(page, PB_migrate_skip, \
  74. PB_migrate_skip)
  75. #define clear_pageblock_skip(page) \
  76. set_pageblock_flags_group(page, 0, PB_migrate_skip, \
  77. PB_migrate_skip)
  78. #define set_pageblock_skip(page) \
  79. set_pageblock_flags_group(page, 1, PB_migrate_skip, \
  80. PB_migrate_skip)
  81. #endif /* CONFIG_COMPACTION */
  82. #endif /* PAGEBLOCK_FLAGS_H */