On Fri, Feb 26, 2021 at 12:47:58PM +0000, Chris Down wrote:
> >    ./include/linux/printk.h:219:5: error: static declaration of 'printk' 
> > follows non-static declaration
> >    219 | int printk(const char *s, ...)
> >     |     ^~~~~~
> >    ./arch/ia64/include/uapi/asm/cmpxchg.h:142:14: note: previous 
> > declaration of 'printk' was here
> >    142 |   extern int printk(const char *fmt, ...);  \
> >     |              ^~~~~~
> > 
> > Make CONFIG_IA64_DEBUG_CMPXCHG dependent on CONFIG_PRINTK to avoid this.

Why not just fix it?

diff --git a/arch/ia64/include/uapi/asm/cmpxchg.h 
b/arch/ia64/include/uapi/asm/cmpxchg.h
index 5d90307fd6e0..d955a8e3ebde 100644
--- a/arch/ia64/include/uapi/asm/cmpxchg.h
+++ b/arch/ia64/include/uapi/asm/cmpxchg.h
@@ -139,7 +139,7 @@ extern long ia64_cmpxchg_called_with_bad_pointer(void);
 do {                                                                   \
        if (_cmpxchg_bugcheck_count-- <= 0) {                           \
                void *ip;                                               \
-               extern int printk(const char *fmt, ...);                \
+               int printk(const char *fmt, ...);                       \
                ip = (void *) ia64_getreg(_IA64_REG_IP);                \
                printk("CMPXCHG_BUGCHECK: stuck at %p on word %p\n", ip, (v));\
                break;                                                  \

Reply via email to