Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

swap: convert swap_writepage() to use a folio

Removes many calls to compound_head().

Link: https://lkml.kernel.org/r/20220902194653.1739778-41-willy@infradead.org
Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>

authored by

Matthew Wilcox (Oracle) and committed by
Andrew Morton
71fa1a53 aedd74d4

+11 -10
+11 -10
mm/page_io.c
··· 180 180 */ 181 181 int swap_writepage(struct page *page, struct writeback_control *wbc) 182 182 { 183 + struct folio *folio = page_folio(page); 183 184 int ret = 0; 184 185 185 - if (try_to_free_swap(page)) { 186 - unlock_page(page); 186 + if (folio_free_swap(folio)) { 187 + folio_unlock(folio); 187 188 goto out; 188 189 } 189 190 /* 190 191 * Arch code may have to preserve more data than just the page 191 192 * contents, e.g. memory tags. 192 193 */ 193 - ret = arch_prepare_to_swap(page); 194 + ret = arch_prepare_to_swap(&folio->page); 194 195 if (ret) { 195 - set_page_dirty(page); 196 - unlock_page(page); 196 + folio_mark_dirty(folio); 197 + folio_unlock(folio); 197 198 goto out; 198 199 } 199 - if (frontswap_store(page) == 0) { 200 - set_page_writeback(page); 201 - unlock_page(page); 202 - end_page_writeback(page); 200 + if (frontswap_store(&folio->page) == 0) { 201 + folio_start_writeback(folio); 202 + folio_unlock(folio); 203 + folio_end_writeback(folio); 203 204 goto out; 204 205 } 205 - ret = __swap_writepage(page, wbc); 206 + ret = __swap_writepage(&folio->page, wbc); 206 207 out: 207 208 return ret; 208 209 }