Re: [BUG] selftests: af_unix: unix:diag.c does not compile on AlmaLinux 8.7

From: Kuniyuki Iwashima
Date: Mon May 22 2023 - 12:29:17 EST


From: Mirsad Todorovac <mirsad.todorovac@xxxxxxxxxxxx>
Date: Mon, 22 May 2023 17:32:11 +0200
> Hi,
>
> On vanilla AlmaLinux 8.7 (CentOS fork) selftests/net/af_unix/diag_uid.c doesn't
> compile out of the box, giving the errors:
>
> make[2]: Entering directory '/home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/net/af_unix'
> gcc diag_uid.c -o /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/net/af_unix/diag_uid
> diag_uid.c:36:16: error: ‘UDIAG_SHOW_UID’ undeclared here (not in a function); did you mean ‘UDIAG_SHOW_VFS’?
> .udiag_show = UDIAG_SHOW_UID
> ^~~~~~~~~~~~~~
> UDIAG_SHOW_VFS
> In file included from diag_uid.c:17:
> diag_uid.c: In function ‘render_response’:
> diag_uid.c:128:28: error: ‘UNIX_DIAG_UID’ undeclared (first use in this function); did you mean ‘UNIX_DIAG_VFS’?
> ASSERT_EQ(attr->rta_type, UNIX_DIAG_UID);
> ^~~~~~~~~~~~~
> ../../kselftest_harness.h:707:13: note: in definition of macro ‘__EXPECT’
> __typeof__(_seen) __seen = (_seen); \
> ^~~~~
> diag_uid.c:128:2: note: in expansion of macro ‘ASSERT_EQ’
> ASSERT_EQ(attr->rta_type, UNIX_DIAG_UID);
> ^~~~~~~~~
> diag_uid.c:128:28: note: each undeclared identifier is reported only once for each function it appears in
> ASSERT_EQ(attr->rta_type, UNIX_DIAG_UID);
> ^~~~~~~~~~~~~
> ../../kselftest_harness.h:707:13: note: in definition of macro ‘__EXPECT’
> __typeof__(_seen) __seen = (_seen); \
> ^~~~~
> diag_uid.c:128:2: note: in expansion of macro ‘ASSERT_EQ’
> ASSERT_EQ(attr->rta_type, UNIX_DIAG_UID);
> ^~~~~~~~~
> make[2]: *** [../../lib.mk:147: /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/net/af_unix/diag_uid] Error 1
>
> The correct value is in <uapi/linux/unix_diag.h>:
>
> include/uapi/linux/unix_diag.h:23:#define UDIAG_SHOW_UID 0x00000040 /* show socket's UID */
>
> The fix is as follows:
>
> ---
> tools/testing/selftests/net/af_unix/diag_uid.c | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/tools/testing/selftests/net/af_unix/diag_uid.c b/tools/testing/selftests/net/af_unix/diag_uid.c
> index 5b88f7129fea..66d75b646d35 100644
> --- a/tools/testing/selftests/net/af_unix/diag_uid.c
> +++ b/tools/testing/selftests/net/af_unix/diag_uid.c
> @@ -16,6 +16,10 @@
>
> #include "../../kselftest_harness.h"
>
> +#ifndef UDIAG_SHOW_UID
> +#define UDIAG_SHOW_UID 0x00000040 /* show socket's UID */
> +#endif
> +
> FIXTURE(diag_uid)
> {
> int netlink_fd;
>
> --
>
> However, this patch reveals another undefined value:
>
> make[2]: Entering directory '/home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/net/af_unix'
> gcc diag_uid.c -o /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/net/af_unix/diag_uid
> In file included from diag_uid.c:17:
> diag_uid.c: In function ‘render_response’:
> diag_uid.c:132:28: error: ‘UNIX_DIAG_UID’ undeclared (first use in this function); did you mean ‘UNIX_DIAG_VFS’?
> ASSERT_EQ(attr->rta_type, UNIX_DIAG_UID);
> ^~~~~~~~~~~~~
> ../../kselftest_harness.h:707:13: note: in definition of macro ‘__EXPECT’
> __typeof__(_seen) __seen = (_seen); \
> ^~~~~
> diag_uid.c:132:2: note: in expansion of macro ‘ASSERT_EQ’
> ASSERT_EQ(attr->rta_type, UNIX_DIAG_UID);
> ^~~~~~~~~
> diag_uid.c:132:28: note: each undeclared identifier is reported only once for each function it appears in
> ASSERT_EQ(attr->rta_type, UNIX_DIAG_UID);
> ^~~~~~~~~~~~~
> ../../kselftest_harness.h:707:13: note: in definition of macro ‘__EXPECT’
> __typeof__(_seen) __seen = (_seen); \
> ^~~~~
> diag_uid.c:132:2: note: in expansion of macro ‘ASSERT_EQ’
> ASSERT_EQ(attr->rta_type, UNIX_DIAG_UID);
> ^~~~~~~~~
> make[2]: *** [../../lib.mk:147: /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/net/af_unix/diag_uid] Error 1
>
> Apparently, AlmaLinux 8.7 lacks this enum UNIX_DIAG_UID:
>
> diff -u /usr/include/linux/unix_diag.h include/uapi/linux/unix_diag.h
> --- /usr/include/linux/unix_diag.h 2023-05-16 13:47:51.000000000 +0200
> +++ include/uapi/linux/unix_diag.h 2022-10-12 07:35:58.253481367 +0200
> @@ -20,6 +20,7 @@
> #define UDIAG_SHOW_ICONS 0x00000008 /* show pending connections */
> #define UDIAG_SHOW_RQLEN 0x00000010 /* show skb receive queue len */
> #define UDIAG_SHOW_MEMINFO 0x00000020 /* show memory info of a socket */
> +#define UDIAG_SHOW_UID 0x00000040 /* show socket's UID */
>
> struct unix_diag_msg {
> __u8 udiag_family;
> @@ -40,6 +41,7 @@
> UNIX_DIAG_RQLEN,
> UNIX_DIAG_MEMINFO,
> UNIX_DIAG_SHUTDOWN,
> + UNIX_DIAG_UID,
>
> __UNIX_DIAG_MAX,
> };
>
> Now, this is a change in enums and there doesn't seem to an easy way out
> here. (I think I saw an example, but I cannot recall which thread. I will do
> more research.)
>
> When I included
>
> # gcc -I ../../../../include diag_uid.c
>
> I've got the following error:
>
> [marvin@pc-mtodorov linux_torvalds]$ cd tools/testing/selftests/net/af_unix/
> [marvin@pc-mtodorov af_unix]$ gcc -I ../../../../../include diag_uid.c -o
> /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/net/af_unix/diag_uid
> In file included from ../../../../../include/linux/build_bug.h:5,
> from ../../../../../include/linux/bits.h:21,
> from ../../../../../include/linux/capability.h:18,
> from ../../../../../include/linux/netlink.h:6,
> from diag_uid.c:8:
> ../../../../../include/linux/compiler.h:246:10: fatal error: asm/rwonce.h: No such file or directory
> #include <asm/rwonce.h>
> ^~~~~~~~~~~~~~
> compilation terminated.
> [marvin@pc-mtodorov af_unix]$
>
> At this point I gave up, as it would be an overkill to change kernel system
> header to make a test pass, and this probably wouldn't be accepted upsteam?
>
> Hope this helps. (If we still want to build on CentOS/AlmaLinux/Rocky 8?)

I launched AlmaLinux/RockyLinux 8.7 and 9.2 with images listed in the pages
below.

https://wiki.almalinux.org/cloud/AWS.html#community-amis
https://rockylinux.org/cloud-images/

The kernel versions in each image were :

8.7:
Alma : 4.18.0-425.3.1.el8.x86_64
Rocky : 4.18.0-425.10.1.el8_7.x86_64

9.2:
Alma : 5.14.0-284.11.1.el9_2.x86_64
Rocky : 5.14.0-284.11.1.el9_2.x86_64

So, this is not a bug. It's just because v4.18 does not support
UNIX_DIAG_UID, which was introduced in v5.3.

You should install 5.3+ kernel if you want to build the test.

Thanks,
Kuniyuki


>
> Best regards,
> Mirsad
>
> --
> Mirsad Goran Todorovac
> Sistem inženjer
> Grafički fakultet | Akademija likovnih umjetnosti
> Sveučilište u Zagrebu
>
> System engineer
> Faculty of Graphic Arts | Academy of Fine Arts
> University of Zagreb, Republic of Croatia