Matthew Wilcox (Oracle) | 2f52578 | 2020-12-10 10:55:05 -0500 | [diff] [blame] | 1 | /* |
| 2 | * Compatibility functions which bloat the callers too much to make inline. |
| 3 | * All of the callers of these functions should be converted to use folios |
| 4 | * eventually. |
| 5 | */ |
| 6 | |
Matthew Wilcox (Oracle) | 3417013 | 2021-05-07 07:28:40 -0400 | [diff] [blame] | 7 | #include <linux/migrate.h> |
Matthew Wilcox (Oracle) | 2f52578 | 2020-12-10 10:55:05 -0500 | [diff] [blame] | 8 | #include <linux/pagemap.h> |
Matthew Wilcox (Oracle) | 76580b6 | 2021-04-27 10:47:39 -0400 | [diff] [blame] | 9 | #include <linux/swap.h> |
Matthew Wilcox (Oracle) | 2f52578 | 2020-12-10 10:55:05 -0500 | [diff] [blame] | 10 | |
| 11 | struct address_space *page_mapping(struct page *page) |
| 12 | { |
| 13 | return folio_mapping(page_folio(page)); |
| 14 | } |
| 15 | EXPORT_SYMBOL(page_mapping); |
Matthew Wilcox (Oracle) | 4e13642 | 2020-12-07 15:44:35 -0500 | [diff] [blame] | 16 | |
| 17 | void unlock_page(struct page *page) |
| 18 | { |
| 19 | return folio_unlock(page_folio(page)); |
| 20 | } |
| 21 | EXPORT_SYMBOL(unlock_page); |
Matthew Wilcox (Oracle) | 4268b48 | 2021-03-03 15:21:55 -0500 | [diff] [blame] | 22 | |
| 23 | void end_page_writeback(struct page *page) |
| 24 | { |
| 25 | return folio_end_writeback(page_folio(page)); |
| 26 | } |
| 27 | EXPORT_SYMBOL(end_page_writeback); |
Matthew Wilcox (Oracle) | 490e016 | 2021-03-04 11:09:17 -0500 | [diff] [blame] | 28 | |
| 29 | void wait_on_page_writeback(struct page *page) |
| 30 | { |
| 31 | return folio_wait_writeback(page_folio(page)); |
| 32 | } |
| 33 | EXPORT_SYMBOL_GPL(wait_on_page_writeback); |
Matthew Wilcox (Oracle) | a49d0c5 | 2021-03-04 11:25:25 -0500 | [diff] [blame] | 34 | |
| 35 | void wait_for_stable_page(struct page *page) |
| 36 | { |
| 37 | return folio_wait_stable(page_folio(page)); |
| 38 | } |
| 39 | EXPORT_SYMBOL_GPL(wait_for_stable_page); |
Matthew Wilcox (Oracle) | dd10ab0 | 2021-04-12 16:45:17 -0400 | [diff] [blame] | 40 | |
| 41 | bool page_mapped(struct page *page) |
| 42 | { |
| 43 | return folio_mapped(page_folio(page)); |
| 44 | } |
| 45 | EXPORT_SYMBOL(page_mapped); |
Matthew Wilcox (Oracle) | 76580b6 | 2021-04-27 10:47:39 -0400 | [diff] [blame] | 46 | |
| 47 | void mark_page_accessed(struct page *page) |
| 48 | { |
| 49 | folio_mark_accessed(page_folio(page)); |
| 50 | } |
| 51 | EXPORT_SYMBOL(mark_page_accessed); |
Matthew Wilcox (Oracle) | 3417013 | 2021-05-07 07:28:40 -0400 | [diff] [blame] | 52 | |
| 53 | #ifdef CONFIG_MIGRATION |
| 54 | int migrate_page_move_mapping(struct address_space *mapping, |
| 55 | struct page *newpage, struct page *page, int extra_count) |
| 56 | { |
| 57 | return folio_migrate_mapping(mapping, page_folio(newpage), |
| 58 | page_folio(page), extra_count); |
| 59 | } |
| 60 | EXPORT_SYMBOL(migrate_page_move_mapping); |
Matthew Wilcox (Oracle) | 1913834 | 2021-05-07 15:26:29 -0400 | [diff] [blame] | 61 | |
| 62 | void migrate_page_states(struct page *newpage, struct page *page) |
| 63 | { |
| 64 | folio_migrate_flags(page_folio(newpage), page_folio(page)); |
| 65 | } |
| 66 | EXPORT_SYMBOL(migrate_page_states); |
Matthew Wilcox (Oracle) | 715cbfd | 2021-05-07 15:05:06 -0400 | [diff] [blame^] | 67 | |
| 68 | void migrate_page_copy(struct page *newpage, struct page *page) |
| 69 | { |
| 70 | folio_migrate_copy(page_folio(newpage), page_folio(page)); |
| 71 | } |
| 72 | EXPORT_SYMBOL(migrate_page_copy); |
Matthew Wilcox (Oracle) | 3417013 | 2021-05-07 07:28:40 -0400 | [diff] [blame] | 73 | #endif |