selftests: net: fix cmsg_so_mark.sh test hang
authorPo-Hsu Lin <po-hsu.lin@canonical.com>
Thu, 29 Dec 2022 05:41:06 +0000 (13:41 +0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 30 Dec 2022 07:37:26 +0000 (07:37 +0000)
This cmsg_so_mark.sh test will hang on non-amd64 systems because of the
infinity loop for argument parsing in cmsg_sender.

Variable "o" in cs_parse_args() for taking getopt() should be an int,
otherwise it will be 255 when getopt() returns -1 on non-amd64 system
and thus causing infinity loop.

Link: https://lore.kernel.org/lkml/CA+G9fYsM2k7mrF7W4V_TrZ-qDauWM394=8yEJ=-t1oUg8_40YA@mail.gmail.com/t/
Signed-off-by: Po-Hsu Lin <po-hsu.lin@canonical.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
tools/testing/selftests/net/cmsg_sender.c

index 75dd83e39207bd38d6943c4eff5d155c005e12d3..24b21b15ed3fb05ba677328c4d68a258d9819169 100644 (file)
@@ -110,7 +110,7 @@ static void __attribute__((noreturn)) cs_usage(const char *bin)
 
 static void cs_parse_args(int argc, char *argv[])
 {
-       char o;
+       int o;
 
        while ((o = getopt(argc, argv, "46sS:p:m:M:d:tf:F:c:C:l:L:H:")) != -1) {
                switch (o) {