]> granicus.if.org Git - strace/blob - tests/ip_mreq.c
Use printnum_int64 instead of print_loff_t
[strace] / tests / ip_mreq.c
1 #ifdef HAVE_CONFIG_H
2 # include "config.h"
3 #endif
4 #include <assert.h>
5 #include <unistd.h>
6 #include <sys/socket.h>
7 #include <netinet/in.h>
8 #include <arpa/inet.h>
9
10 int
11 main(void)
12 {
13 #if defined IP_ADD_MEMBERSHIP && defined IPV6_ADD_MEMBERSHIP \
14  && defined IPV6_JOIN_ANYCAST && defined HAVE_INET_PTON
15         struct ip_mreq m4;
16         struct ipv6_mreq m6;
17
18         inet_pton(AF_INET, "224.0.0.3", &m4.imr_multiaddr);
19         inet_pton(AF_INET, "127.0.0.1", &m4.imr_interface);
20         inet_pton(AF_INET6, "ff01::c", &m6.ipv6mr_multiaddr);
21         m6.ipv6mr_interface = 1;
22
23         (void) close(0);
24         assert(socket(AF_INET, SOCK_DGRAM, 0) == 0);
25
26         assert(setsockopt(0, SOL_IP, IP_ADD_MEMBERSHIP, &m4, 1) == -1);
27         assert(setsockopt(0, SOL_IP, IP_DROP_MEMBERSHIP, &m4, 1) == -1);
28         assert(setsockopt(0, SOL_IP, IP_ADD_MEMBERSHIP, &m4, sizeof(m4)) == 0);
29         assert(setsockopt(0, SOL_IP, IP_DROP_MEMBERSHIP, &m4, sizeof(m4)) == 0);
30
31         assert(setsockopt(0, SOL_IPV6, IPV6_ADD_MEMBERSHIP, &m6, 1) == -1);
32         assert(setsockopt(0, SOL_IPV6, IPV6_DROP_MEMBERSHIP, &m6, 1) == -1);
33         assert(setsockopt(0, SOL_IPV6, IPV6_ADD_MEMBERSHIP, &m6, sizeof(m6)) == -1);
34         assert(setsockopt(0, SOL_IPV6, IPV6_DROP_MEMBERSHIP, &m6, sizeof(m6)) == -1);
35
36         assert(setsockopt(0, SOL_IPV6, IPV6_JOIN_ANYCAST, &m6, 1) == -1);
37         assert(setsockopt(0, SOL_IPV6, IPV6_LEAVE_ANYCAST, &m6, 1) == -1);
38         assert(setsockopt(0, SOL_IPV6, IPV6_JOIN_ANYCAST, &m6, sizeof(m6)) == -1);
39         assert(setsockopt(0, SOL_IPV6, IPV6_LEAVE_ANYCAST, &m6, sizeof(m6)) == -1);
40
41         return 0;
42 #else
43         return 77;
44 #endif
45 }