xref: /xnu-12377.81.4/tests/mcast_group_race_82820812.c (revision 043036a2b3718f7f0be807e2870f8f47d3fa0796)
1*043036a2SApple OSS Distributions #include <arpa/inet.h>
2*043036a2SApple OSS Distributions #include <pthread.h>
3*043036a2SApple OSS Distributions #include <unistd.h>
4*043036a2SApple OSS Distributions #include <darwintest.h>
5*043036a2SApple OSS Distributions #include <TargetConditionals.h>
6*043036a2SApple OSS Distributions 
7*043036a2SApple OSS Distributions #include <mach/mach_host.h>
8*043036a2SApple OSS Distributions 
9*043036a2SApple OSS Distributions #include "net_test_lib.h"
10*043036a2SApple OSS Distributions 
11*043036a2SApple OSS Distributions volatile static int lock_a;
12*043036a2SApple OSS Distributions volatile static int lock_b;
13*043036a2SApple OSS Distributions 
14*043036a2SApple OSS Distributions static int fd;
15*043036a2SApple OSS Distributions static struct sockaddr_in saddr;
16*043036a2SApple OSS Distributions 
17*043036a2SApple OSS Distributions static struct ip_mreq filler_group;
18*043036a2SApple OSS Distributions static struct ip_mreq group_a;
19*043036a2SApple OSS Distributions static struct ip_mreq group_b;
20*043036a2SApple OSS Distributions 
21*043036a2SApple OSS Distributions #define ITERATIONS_LIMIT 1000
22*043036a2SApple OSS Distributions 
23*043036a2SApple OSS Distributions static void *
thread_func(__unused void * arg)24*043036a2SApple OSS Distributions thread_func(__unused void* arg)
25*043036a2SApple OSS Distributions {
26*043036a2SApple OSS Distributions 	lock_a = 1;
27*043036a2SApple OSS Distributions 	while (lock_b == 0) {
28*043036a2SApple OSS Distributions 	}
29*043036a2SApple OSS Distributions 
30*043036a2SApple OSS Distributions 	setsockopt(fd, IPPROTO_IP, IP_ADD_MEMBERSHIP, &group_a, sizeof(group_a));
31*043036a2SApple OSS Distributions 
32*043036a2SApple OSS Distributions 	return NULL;
33*043036a2SApple OSS Distributions }
34*043036a2SApple OSS Distributions 
35*043036a2SApple OSS Distributions T_DECL(mcast_group_race_82820812, "Race between multicast group join operations.",
36*043036a2SApple OSS Distributions     T_META_ASROOT(true),
37*043036a2SApple OSS Distributions     T_META_ENABLED(!TARGET_OS_BRIDGE && !TARGET_OS_SIMULATOR))
38*043036a2SApple OSS Distributions {
39*043036a2SApple OSS Distributions 	pthread_t th;
40*043036a2SApple OSS Distributions 	uint32_t i = 0;
41*043036a2SApple OSS Distributions 	uint32_t j = 0;
42*043036a2SApple OSS Distributions 
43*043036a2SApple OSS Distributions 	saddr.sin_family = AF_INET;
44*043036a2SApple OSS Distributions 
45*043036a2SApple OSS Distributions 	group_a.imr_multiaddr.s_addr = inet_addr("224.0.0.1");
46*043036a2SApple OSS Distributions 	group_b.imr_multiaddr.s_addr = inet_addr("224.0.0.2");
47*043036a2SApple OSS Distributions 
48*043036a2SApple OSS Distributions 	for (i = 0; i < ITERATIONS_LIMIT; ++i) {
49*043036a2SApple OSS Distributions 		T_ASSERT_POSIX_SUCCESS(fd = socket(AF_INET, SOCK_DGRAM, 0), "socket");
50*043036a2SApple OSS Distributions 		T_ASSERT_POSIX_SUCCESS(bind(fd, (struct sockaddr *) &saddr, sizeof(saddr)), "bind");
51*043036a2SApple OSS Distributions 
52*043036a2SApple OSS Distributions 		for (j = 0; j < IP_MIN_MEMBERSHIPS - 1; ++j) {
53*043036a2SApple OSS Distributions 			filler_group.imr_multiaddr.s_addr = htonl(ntohl(inet_addr("224.0.0.3")) + j);
54*043036a2SApple OSS Distributions 			setsockopt(fd, IPPROTO_IP, IP_ADD_MEMBERSHIP, &filler_group, sizeof(filler_group));
55*043036a2SApple OSS Distributions 		}
56*043036a2SApple OSS Distributions 
57*043036a2SApple OSS Distributions 		T_ASSERT_POSIX_ZERO(pthread_create(&th, NULL, thread_func, NULL), "pthread_create");
58*043036a2SApple OSS Distributions 
59*043036a2SApple OSS Distributions 		while (lock_a == 0) {
60*043036a2SApple OSS Distributions 		}
61*043036a2SApple OSS Distributions 		lock_b = 1;
62*043036a2SApple OSS Distributions 
63*043036a2SApple OSS Distributions 		setsockopt(fd, IPPROTO_IP, IP_ADD_MEMBERSHIP, &group_b, sizeof(group_b));
64*043036a2SApple OSS Distributions 
65*043036a2SApple OSS Distributions 		T_ASSERT_POSIX_ZERO(pthread_join(th, NULL), "pthread_join");
66*043036a2SApple OSS Distributions 		T_ASSERT_POSIX_SUCCESS(close(fd), "close");
67*043036a2SApple OSS Distributions 	}
68*043036a2SApple OSS Distributions 
69*043036a2SApple OSS Distributions 	force_zone_gc();
70*043036a2SApple OSS Distributions }
71