On 05/16/2018 01:33 PM, Szabolcs Nagy wrote: > On 16/05/18 12:19, Dmitry V. Levin wrote: >> On Wed, May 16, 2018 at 12:10:40PM +0100, Szabolcs Nagy wrote: >>> glibc sysdeps/unix/sysv/linux/bits/mman-shared.h: >>> >>> int pkey_alloc (unsigned int __flags, unsigned int __access_rights) __THROW; >>> >>> linux-man http://man7.org/linux/man-pages/man2/pkey_alloc.2.html : >>> >>> int pkey_alloc(unsigned long flags, unsigned long access_rights); >>> >>> i assume the documentation should be fixed (as the glibc >>> code is already in use) >> >> Note that pkey_alloc syscall takes arguments of type "unsigned long" >> and explicitly tests them for unsupported bits. >> >> > > i see, but this is a general bug in the way the syscalls are > documented: a syscall is not a c function, so a c declaration > is not the right way to document it (the pcs does not even > work for syscalls and the linux uapi headers do not provide > magic inline wrappers usable from freestanding c code). > > the libc api is in c so that is reasonable to document using > the c language (using c/posix types). > > so i recommend making the distinction between kernel uapi, > syscall abi and libc api clear when they disagree about types. > > in this case the man says '#include <sys/mman.h>' which is > a libc header, so the declaration has to match whatever is > in there otherwise it's misleading. In cases like these, the section 2 man pages tend to document the libc interface. The reason that "unsigned long" was shown was that until now there was no libc interface. I've amended the manual page to use "unsigned int" for both arguments. Thanks for CCing linux-man@ Cheers, Michael -- Michael Kerrisk Linux man-pages maintainer; http://www.kernel.org/doc/man-pages/ Linux/UNIX System Programming Training: http://man7.org/training/ -- To unsubscribe from this list: send the line "unsubscribe linux-man" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html