mirror of
https://passt.top/passt
synced 2025-01-03 03:15:22 +00:00
tap: Explicitly cast TUNSETIFF to fix build warning with musl on ppc64le
On ppc64le, TUNSETIFF happens to be 2147767498, which is bigger than INT_MAX (2^31 - 1), and musl declares the second argument of ioctl() as 'int', not 'unsigned long' like glibc does, probably because of how POSIX specifies the equivalent argument, int dcmd, in posix_devctl(), so gcc reports a warning: tap.c: In function 'tap_ns_tun': tap.c:1291:24: warning: overflow in conversion from 'long unsigned int' to 'int' changes value from '2147767498' to '-2147199798' [-Woverflow] 1291 | rc = ioctl(fd, TUNSETIFF, &ifr); | ^~~~~~~~~ We don't care about that overflow, so explicitly cast TUNSETIFF to int. Signed-off-by: Stefano Brivio <sbrivio@redhat.com> Reviewed-by: David Gibson <david@gibson.dropbear.id.au>
This commit is contained in:
parent
d165d36a0c
commit
9afce0b45c
2
tap.c
2
tap.c
@ -1288,7 +1288,7 @@ static int tap_ns_tun(void *arg)
|
|||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
die_perror("Failed to open() /dev/net/tun");
|
die_perror("Failed to open() /dev/net/tun");
|
||||||
|
|
||||||
rc = ioctl(fd, TUNSETIFF, &ifr);
|
rc = ioctl(fd, (int)TUNSETIFF, &ifr);
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
die_perror("TUNSETIFF ioctl on /dev/net/tun failed");
|
die_perror("TUNSETIFF ioctl on /dev/net/tun failed");
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user