Re: [PATCH v2 2/5] parisc: add __NR_Linux_syscalls macro with __NR_syscalls
From: Arnd Bergmann
Date: Fri Sep 28 2018 - 08:14:45 EST
On Thu, Sep 27, 2018 at 4:25 PM Firoz Khan <firoz.khan@xxxxxxxxxx> wrote:
>
> 1. Update __NR_Linux_syscalls in uapi/asm/unistd.h manually
> by counting the no.of system calls. No need to update
> __NR_Linux_syscalls until we either add a new system call
> or delete an existing system call.
>
> 2. We can keep this feature it above mentioned script, that
> will count the number of syscalls and keep it in a gener-
> ated file. In this case we don't need to explicitly update
> __NR_Linux_syscalls in asm/unistd.h file.
>
> The 2nd option will be the recommended one. For that, I moved
> the __NR_Linux_syscalls macro from uapi/asm/unistd.h to asm/
> unistd.h. The macro __NR_syscalls also added for making the
> name convention same across all architecture. While __NR_sys-
> calls isn't strictly part of the uapi, having it as part of
> the generated header to simplifies the implementation. We also
> need to enclose this macro with #ifdef __KERNEL__ to avoid side
> effects.
>
> Signed-off-by: Firoz Khan <firoz.khan@xxxxxxxxxx>
> ---
> arch/parisc/include/uapi/asm/unistd.h | 6 +++++-
> 1 file changed, 5 insertions(+), 1 deletion(-)
>
> diff --git a/arch/parisc/include/uapi/asm/unistd.h b/arch/parisc/include/uapi/asm/unistd.h
> index bb52e12..255c62a 100644
> --- a/arch/parisc/include/uapi/asm/unistd.h
> +++ b/arch/parisc/include/uapi/asm/unistd.h
> @@ -366,7 +366,11 @@
> #define __NR_statx (__NR_Linux + 349)
> #define __NR_io_pgetevents (__NR_Linux + 350)
>
> -#define __NR_Linux_syscalls (__NR_io_pgetevents + 1)
> +#ifdef __KERNEL__
> +#define __NR_syscalls 351
> +#endif
> +
> +#define __NR_Linux_syscalls __NR_syscalls
>
Hmm, now you have a __NR_Linux_syscalls macro that is defined in user
space to a another macro that is not visible there. How about moving
__NR_Linux_syscalls into arch/parisc/include/asm/unistd.h or
replacing its users with __NR_syscalls instead?
Arnd