From: Arnd Bergmann <arnd@xxxxxxxx> It's only used from inside of an #ifdef section, causing a warning otherwise: mm/zsmalloc.c:735:23: error: unused function 'get_zspage_lockless' [-Werror,-Wunused-function] 735 | static struct zspage *get_zspage_lockless(struct page *page) | ^~~~~~~~~~~~~~~~~~~ Move it down into that block to avoid adding another #ifdef. Fixes: 2258bdebb55e ("mm/zsmalloc: don't hold locks of all pages when free_zspage()") Signed-off-by: Arnd Bergmann <arnd@xxxxxxxx> --- mm/zsmalloc.c | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/mm/zsmalloc.c b/mm/zsmalloc.c index 1a044690b389..11422305d819 100644 --- a/mm/zsmalloc.c +++ b/mm/zsmalloc.c @@ -731,14 +731,6 @@ static struct zspage *get_zspage(struct page *page) return zspage; } -/* Only used in zs_page_migrate() to get zspage locklessly. */ -static struct zspage *get_zspage_lockless(struct page *page) -{ - struct zspage __rcu **private = (struct zspage __rcu **)&page->private; - - return rcu_dereference(*private); -} - static struct page *get_next_page(struct page *page) { struct zspage *zspage = get_zspage(page); @@ -1651,6 +1643,13 @@ static void migrate_write_unlock(struct zspage *zspage) } #ifdef CONFIG_COMPACTION +/* Only used in zs_page_migrate() to get zspage locklessly. */ +static struct zspage *get_zspage_lockless(struct page *page) +{ + struct zspage __rcu **private = (struct zspage __rcu **)&page->private; + + return rcu_dereference(*private); +} static const struct movable_operations zsmalloc_mops; -- 2.39.2