Re: [PATCH v3 1/8] x86, syscalls: Refactor SYSCALL_DEFINEx macros

From: Andy Lutomirski
Date: Fri Feb 28 2020 - 13:34:00 EST


On Thu, Feb 27, 2020 at 5:28 AM Brian Gerst <brgerst@xxxxxxxxx> wrote:
>
> Pull the common code out from the SYSCALL_DEFINEx macros into a new
> __SYS_STUBx macro. Also conditionalize the X64 version in preparation for
> enabling syscall wrappers on 32-bit native kernels.
>
> Signed-off-by: Brian Gerst <brgerst@xxxxxxxxx>
> ---



> -#define COMPAT_SYSCALL_DEFINEx(x, name, ...) \
> - static long __se_compat_sys##name(__MAP(x,__SC_LONG,__VA_ARGS__)); \
> - static inline long __do_compat_sys##name(__MAP(x,__SC_DECL,__VA_ARGS__));\
> - __IA32_COMPAT_SYS_STUBx(x, name, __VA_ARGS__) \
> - __X32_COMPAT_SYS_STUBx(x, name, __VA_ARGS__) \
> - static long __se_compat_sys##name(__MAP(x,__SC_LONG,__VA_ARGS__)) \
> - { \
> - return __do_compat_sys##name(__MAP(x,__SC_DELOUSE,__VA_ARGS__));\
> - } \
> - static inline long __do_compat_sys##name(__MAP(x,__SC_DECL,__VA_ARGS__))
> +#define COMPAT_SYSCALL_DEFINEx(x, name, ...) \
> + static long \
> + __se_compat_sys##name(__MAP(x, __SC_LONG, __VA_ARGS__)); \
> + static inline long \
> + __do_compat_sys##name(__MAP(x, __SC_DECL, __VA_ARGS__)); \
> + __IA32_COMPAT_SYS_STUBx(x, name, __VA_ARGS__) \
> + __X32_COMPAT_SYS_STUBx(x, name, __VA_ARGS__) \
> + static long \
> + __se_compat_sys##name(__MAP(x, __SC_LONG, __VA_ARGS__)) \
> + { \
> + return __do_compat_sys##name( \
> + __MAP(x, __SC_DELOUSE, __VA_ARGS__)); \
> + } \
> + static inline long \
> + __do_compat_sys##name(__MAP(x, __SC_DECL, __VA_ARGS__))
>

This hunk looks like a pure anti-cleanup. I much prefer slightly long
lines over messy excessively multi-line macros.

Other than that:

Reviewed-by: Andy Lutomirski <luto@xxxxxxxxxx>

--Andy