pagevec.h 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /*
  2. * include/linux/pagevec.h
  3. *
  4. * In many places it is efficient to batch an operation up against multiple
  5. * pages. A pagevec is a multipage container which is used for that.
  6. */
  7. #ifndef _LINUX_PAGEVEC_H
  8. #define _LINUX_PAGEVEC_H
  9. /* 14 pointers + two long's align the pagevec structure to a power of two */
  10. #define PAGEVEC_SIZE 14
  11. struct page;
  12. struct address_space;
  13. struct pagevec {
  14. unsigned long nr;
  15. unsigned long cold;
  16. struct page *pages[PAGEVEC_SIZE];
  17. };
  18. void __pagevec_release(struct pagevec *pvec);
  19. void ____pagevec_lru_add(struct pagevec *pvec, enum lru_list lru);
  20. void pagevec_strip(struct pagevec *pvec);
  21. unsigned pagevec_lookup(struct pagevec *pvec, struct address_space *mapping,
  22. pgoff_t start, unsigned nr_pages);
  23. unsigned pagevec_lookup_tag(struct pagevec *pvec,
  24. struct address_space *mapping, pgoff_t *index, int tag,
  25. unsigned nr_pages);
  26. static inline void pagevec_init(struct pagevec *pvec, int cold)
  27. {
  28. pvec->nr = 0;
  29. pvec->cold = cold;
  30. }
  31. static inline void pagevec_reinit(struct pagevec *pvec)
  32. {
  33. pvec->nr = 0;
  34. }
  35. static inline unsigned pagevec_count(struct pagevec *pvec)
  36. {
  37. return pvec->nr;
  38. }
  39. static inline unsigned pagevec_space(struct pagevec *pvec)
  40. {
  41. return PAGEVEC_SIZE - pvec->nr;
  42. }
  43. /*
  44. * Add a page to a pagevec. Returns the number of slots still available.
  45. */
  46. static inline unsigned pagevec_add(struct pagevec *pvec, struct page *page)
  47. {
  48. pvec->pages[pvec->nr++] = page;
  49. return pagevec_space(pvec);
  50. }
  51. static inline void pagevec_release(struct pagevec *pvec)
  52. {
  53. if (pagevec_count(pvec))
  54. __pagevec_release(pvec);
  55. }
  56. static inline void __pagevec_lru_add_anon(struct pagevec *pvec)
  57. {
  58. ____pagevec_lru_add(pvec, LRU_INACTIVE_ANON);
  59. }
  60. static inline void __pagevec_lru_add_active_anon(struct pagevec *pvec)
  61. {
  62. ____pagevec_lru_add(pvec, LRU_ACTIVE_ANON);
  63. }
  64. static inline void __pagevec_lru_add_file(struct pagevec *pvec)
  65. {
  66. ____pagevec_lru_add(pvec, LRU_INACTIVE_FILE);
  67. }
  68. static inline void __pagevec_lru_add_active_file(struct pagevec *pvec)
  69. {
  70. ____pagevec_lru_add(pvec, LRU_ACTIVE_FILE);
  71. }
  72. static inline void pagevec_lru_add_file(struct pagevec *pvec)
  73. {
  74. if (pagevec_count(pvec))
  75. __pagevec_lru_add_file(pvec);
  76. }
  77. static inline void pagevec_lru_add_anon(struct pagevec *pvec)
  78. {
  79. if (pagevec_count(pvec))
  80. __pagevec_lru_add_anon(pvec);
  81. }
  82. #endif /* _LINUX_PAGEVEC_H */