]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
sparc: Avoid -Wunused-but-set-parameter in clear_user_page()
authorThomas Weißschuh <linux@weissschuh.net>
Mon, 25 May 2026 08:36:21 +0000 (10:36 +0200)
committerAndreas Larsson <andreas@gaisler.com>
Fri, 12 Jun 2026 11:57:06 +0000 (13:57 +0200)
The loop in clear_user_pages() iterates over all pages and calls
clear_user_page() for each of them. During the loop "vaddr" is modified.
However on sparc clear_user() is a macro which does not use "vaddr".
The compiler sees a variable which is modified but never used and emits
a warning for that:

include/linux/highmem.h: In function 'clear_user_pages':
include/linux/highmem.h:234:63: warning: parameter 'vaddr' set but not used [-Wunused-but-set-parameter=]
static inline void clear_user_pages(void *addr, unsigned long vaddr,

Other architectures use an inline function for clear_user_page() which
avoids the warning. This is not possible on sparc, as
sparc_flush_page_to_ram() is not yet declared where clear_user_page() is
defined. Including cacheflush_32.h will trigger recursive and lots of
other issues.

So hide the warning with a cast to (void) instead.

While we are here, do the same for copy_user_page().

Fixes: 62a9f5a85b98 ("mm: introduce clear_pages() and clear_user_pages()")
Signed-off-by: Thomas Weißschuh <linux@weissschuh.net>
Reviewed-by: Andreas Larsson <andreas@gaisler.com>
Signed-off-by: Andreas Larsson <andreas@gaisler.com>
arch/sparc/include/asm/page_32.h

index c1bccbedf567ec2b436b93d00f3a7491f524cb2b..9f0b54f709088f04035fb4a1d3290513012b5f08 100644 (file)
 #define clear_user_page(addr, vaddr, page)     \
        do {    clear_page(addr);               \
                sparc_flush_page_to_ram(page);  \
+               (void)(vaddr);                  \
        } while (0)
 #define copy_user_page(to, from, vaddr, page)  \
        do {    copy_page(to, from);            \
                sparc_flush_page_to_ram(page);  \
+               (void)(vaddr);                  \
        } while (0)
 
 /* The following structure is used to hold the physical