Commit 82f6f5b2 authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Stefan Bader

appletalk: Fix compile regression

BugLink: https://bugs.launchpad.net/bugs/1828420

[ Upstream commit 27da0d2e ]

A bugfix just broke compilation of appletalk when CONFIG_SYSCTL
is disabled:

In file included from net/appletalk/ddp.c:65:
net/appletalk/ddp.c: In function 'atalk_init':
include/linux/atalk.h:164:34: error: expected expression before 'do'
 #define atalk_register_sysctl()  do { } while(0)
                                  ^~
net/appletalk/ddp.c:1934:7: note: in expansion of macro 'atalk_register_sysctl'
  rc = atalk_register_sysctl();

This is easier to avoid by using conventional inline functions
as stubs rather than macros. The header already has inline
functions for other purposes, so I'm changing over all the
macros for consistency.

Fixes: 6377f787 ("appletalk: Fix use-after-free in atalk_proc_exit")
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
Signed-off-by: default avatarKleber Sacilotto de Souza <kleber.souza@canonical.com>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
parent a1d9297d
...@@ -153,16 +153,26 @@ extern int sysctl_aarp_resolve_time; ...@@ -153,16 +153,26 @@ extern int sysctl_aarp_resolve_time;
extern int atalk_register_sysctl(void); extern int atalk_register_sysctl(void);
extern void atalk_unregister_sysctl(void); extern void atalk_unregister_sysctl(void);
#else #else
#define atalk_register_sysctl() do { } while(0) static inline int atalk_register_sysctl(void)
#define atalk_unregister_sysctl() do { } while(0) {
return 0;
}
static inline void atalk_unregister_sysctl(void)
{
}
#endif #endif
#ifdef CONFIG_PROC_FS #ifdef CONFIG_PROC_FS
extern int atalk_proc_init(void); extern int atalk_proc_init(void);
extern void atalk_proc_exit(void); extern void atalk_proc_exit(void);
#else #else
#define atalk_proc_init() ({ 0; }) static inline int atalk_proc_init(void)
#define atalk_proc_exit() do { } while(0) {
return 0;
}
static inline void atalk_proc_exit(void)
{
}
#endif /* CONFIG_PROC_FS */ #endif /* CONFIG_PROC_FS */
#endif /* __LINUX_ATALK_H__ */ #endif /* __LINUX_ATALK_H__ */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment