xref: /xnu-12377.61.12/tests/udp_bind_connect.c (revision 4d495c6e23c53686cf65f45067f79024cf5dcee8)
1*4d495c6eSApple OSS Distributions /*
2*4d495c6eSApple OSS Distributions  * Copyright (c) 2022-2024 Apple Inc. All rights reserved.
3*4d495c6eSApple OSS Distributions  *
4*4d495c6eSApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*4d495c6eSApple OSS Distributions  *
6*4d495c6eSApple OSS Distributions  * This file contains Original Code and/or Modifications of Original Code
7*4d495c6eSApple OSS Distributions  * as defined in and that are subject to the Apple Public Source License
8*4d495c6eSApple OSS Distributions  * Version 2.0 (the 'License'). You may not use this file except in
9*4d495c6eSApple OSS Distributions  * compliance with the License. The rights granted to you under the License
10*4d495c6eSApple OSS Distributions  * may not be used to create, or enable the creation or redistribution of,
11*4d495c6eSApple OSS Distributions  * unlawful or unlicensed copies of an Apple operating system, or to
12*4d495c6eSApple OSS Distributions  * circumvent, violate, or enable the circumvention or violation of, any
13*4d495c6eSApple OSS Distributions  * terms of an Apple operating system software license agreement.
14*4d495c6eSApple OSS Distributions  *
15*4d495c6eSApple OSS Distributions  * Please obtain a copy of the License at
16*4d495c6eSApple OSS Distributions  * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*4d495c6eSApple OSS Distributions  *
18*4d495c6eSApple OSS Distributions  * The Original Code and all software distributed under the License are
19*4d495c6eSApple OSS Distributions  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*4d495c6eSApple OSS Distributions  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*4d495c6eSApple OSS Distributions  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*4d495c6eSApple OSS Distributions  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*4d495c6eSApple OSS Distributions  * Please see the License for the specific language governing rights and
24*4d495c6eSApple OSS Distributions  * limitations under the License.
25*4d495c6eSApple OSS Distributions  *
26*4d495c6eSApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*4d495c6eSApple OSS Distributions  */
28*4d495c6eSApple OSS Distributions 
29*4d495c6eSApple OSS Distributions #include <sys/fcntl.h>
30*4d495c6eSApple OSS Distributions #include <sys/socket.h>
31*4d495c6eSApple OSS Distributions 
32*4d495c6eSApple OSS Distributions #include <net/if.h>
33*4d495c6eSApple OSS Distributions #include <net/route.h>
34*4d495c6eSApple OSS Distributions 
35*4d495c6eSApple OSS Distributions #include <netinet/in.h>
36*4d495c6eSApple OSS Distributions 
37*4d495c6eSApple OSS Distributions #include <stdbool.h>
38*4d495c6eSApple OSS Distributions #include <stdlib.h>
39*4d495c6eSApple OSS Distributions #include <string.h>
40*4d495c6eSApple OSS Distributions #include <unistd.h>
41*4d495c6eSApple OSS Distributions 
42*4d495c6eSApple OSS Distributions #include <arpa/inet.h>
43*4d495c6eSApple OSS Distributions 
44*4d495c6eSApple OSS Distributions #include <darwintest.h>
45*4d495c6eSApple OSS Distributions 
46*4d495c6eSApple OSS Distributions #include "net_test_lib.h"
47*4d495c6eSApple OSS Distributions 
48*4d495c6eSApple OSS Distributions T_GLOBAL_META(
49*4d495c6eSApple OSS Distributions 	T_META_NAMESPACE("xnu.net"),
50*4d495c6eSApple OSS Distributions 	T_META_RADAR_COMPONENT_NAME("xnu"),
51*4d495c6eSApple OSS Distributions 	T_META_RADAR_COMPONENT_VERSION("networking")
52*4d495c6eSApple OSS Distributions 	);
53*4d495c6eSApple OSS Distributions 
54*4d495c6eSApple OSS Distributions #define MAX_IPv6_STR_LEN        64
55*4d495c6eSApple OSS Distributions 
56*4d495c6eSApple OSS Distributions static char l_addr_str[MAX_IPv6_STR_LEN];
57*4d495c6eSApple OSS Distributions static char f_addr_str[MAX_IPv6_STR_LEN];
58*4d495c6eSApple OSS Distributions 
59*4d495c6eSApple OSS Distributions const struct in6_addr in6addr_any = IN6ADDR_ANY_INIT;
60*4d495c6eSApple OSS Distributions #define s6_addr32 __u6_addr.__u6_addr32
61*4d495c6eSApple OSS Distributions 
62*4d495c6eSApple OSS Distributions 
63*4d495c6eSApple OSS Distributions static void
init_sin_address(struct sockaddr_in * sin)64*4d495c6eSApple OSS Distributions init_sin_address(struct sockaddr_in *sin)
65*4d495c6eSApple OSS Distributions {
66*4d495c6eSApple OSS Distributions 	memset(sin, 0, sizeof(struct sockaddr_in));
67*4d495c6eSApple OSS Distributions 	sin->sin_len = sizeof(struct sockaddr_in);
68*4d495c6eSApple OSS Distributions 	sin->sin_family = AF_INET;
69*4d495c6eSApple OSS Distributions }
70*4d495c6eSApple OSS Distributions 
71*4d495c6eSApple OSS Distributions static void
init_sin6_address(struct sockaddr_in6 * sin6)72*4d495c6eSApple OSS Distributions init_sin6_address(struct sockaddr_in6 *sin6)
73*4d495c6eSApple OSS Distributions {
74*4d495c6eSApple OSS Distributions 	memset(sin6, 0, sizeof(struct sockaddr_in6));
75*4d495c6eSApple OSS Distributions 	sin6->sin6_len = sizeof(struct sockaddr_in6);
76*4d495c6eSApple OSS Distributions 	sin6->sin6_family = AF_INET6;
77*4d495c6eSApple OSS Distributions }
78*4d495c6eSApple OSS Distributions 
79*4d495c6eSApple OSS Distributions static void
udp_connect_v4(int client_fd,struct sockaddr_in * sin_to,int expected_error)80*4d495c6eSApple OSS Distributions udp_connect_v4(int client_fd, struct sockaddr_in *sin_to, int expected_error)
81*4d495c6eSApple OSS Distributions {
82*4d495c6eSApple OSS Distributions 	int listen_fd = -1;
83*4d495c6eSApple OSS Distributions 	socklen_t socklen;
84*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin_local = { 0 };
85*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin_peer = { 0 };
86*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin;
87*4d495c6eSApple OSS Distributions 
88*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
89*4d495c6eSApple OSS Distributions 	init_sin_address(&sin_local);
90*4d495c6eSApple OSS Distributions 	init_sin_address(&sin_peer);
91*4d495c6eSApple OSS Distributions 
92*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(listen_fd = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
93*4d495c6eSApple OSS Distributions 
94*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(listen_fd, (struct sockaddr *)&sin, sizeof(sin)), NULL);
95*4d495c6eSApple OSS Distributions 
96*4d495c6eSApple OSS Distributions 	socklen = sizeof(sin);
97*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(getsockname(listen_fd, (struct sockaddr *)&sin, &socklen), NULL);
98*4d495c6eSApple OSS Distributions 
99*4d495c6eSApple OSS Distributions 	T_LOG("listening on port: %u", ntohs(sin.sin_port));
100*4d495c6eSApple OSS Distributions 	sin_to->sin_port = sin.sin_port;
101*4d495c6eSApple OSS Distributions 
102*4d495c6eSApple OSS Distributions 	T_LOG("connect with sin_len: %u sin_family: %u sin_port: %u sin_addr: 0x%08x expected_error: %d",
103*4d495c6eSApple OSS Distributions 	    sin_to->sin_len, sin_to->sin_family, ntohs(sin_to->sin_port), ntohl(sin_to->sin_addr.s_addr), expected_error);
104*4d495c6eSApple OSS Distributions 
105*4d495c6eSApple OSS Distributions 	if (expected_error == 0) {
106*4d495c6eSApple OSS Distributions 		T_EXPECT_POSIX_SUCCESS(connect(client_fd, (struct sockaddr *)sin_to, sizeof(struct sockaddr_in)), NULL);
107*4d495c6eSApple OSS Distributions 
108*4d495c6eSApple OSS Distributions 		socklen = sizeof(sin_local);
109*4d495c6eSApple OSS Distributions 		T_ASSERT_POSIX_SUCCESS(getsockname(client_fd, (struct sockaddr *)&sin_local, &socklen), NULL);
110*4d495c6eSApple OSS Distributions 		(void)inet_ntop(AF_INET, &sin_local.sin_addr, l_addr_str, sizeof(l_addr_str));
111*4d495c6eSApple OSS Distributions 
112*4d495c6eSApple OSS Distributions 		socklen = sizeof(sin_peer);
113*4d495c6eSApple OSS Distributions 		T_ASSERT_POSIX_SUCCESS(getpeername(client_fd, (struct sockaddr *)&sin_peer, &socklen), NULL);
114*4d495c6eSApple OSS Distributions 		(void)inet_ntop(AF_INET, &sin_peer.sin_addr, f_addr_str, sizeof(f_addr_str));
115*4d495c6eSApple OSS Distributions 
116*4d495c6eSApple OSS Distributions 		T_LOG("connected from %s:%u to %s:%u",
117*4d495c6eSApple OSS Distributions 		    l_addr_str, ntohs(sin_local.sin_port),
118*4d495c6eSApple OSS Distributions 		    f_addr_str, ntohs(sin_peer.sin_port));
119*4d495c6eSApple OSS Distributions 	} else {
120*4d495c6eSApple OSS Distributions 		T_EXPECT_POSIX_FAILURE(connect(client_fd, (struct sockaddr *)sin_to, sizeof(struct sockaddr_in)), expected_error, NULL);
121*4d495c6eSApple OSS Distributions 	}
122*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(listen_fd), NULL);
123*4d495c6eSApple OSS Distributions }
124*4d495c6eSApple OSS Distributions 
125*4d495c6eSApple OSS Distributions static void
udp_connect_v6(int client_fd,struct sockaddr_in6 * sin6_to,int expected_error)126*4d495c6eSApple OSS Distributions udp_connect_v6(int client_fd, struct sockaddr_in6 *sin6_to, int expected_error)
127*4d495c6eSApple OSS Distributions {
128*4d495c6eSApple OSS Distributions 	int listen_fd = -1;
129*4d495c6eSApple OSS Distributions 	socklen_t socklen;
130*4d495c6eSApple OSS Distributions 	int off = 0;
131*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6_local = { 0 };
132*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6_peer = { 0 };
133*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6;
134*4d495c6eSApple OSS Distributions 
135*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
136*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6_local);
137*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6_peer);
138*4d495c6eSApple OSS Distributions 
139*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(listen_fd = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
140*4d495c6eSApple OSS Distributions 
141*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(setsockopt(listen_fd, IPPROTO_IPV6, IPV6_V6ONLY, &off, sizeof(off)), NULL);
142*4d495c6eSApple OSS Distributions 
143*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(listen_fd, (struct sockaddr *)&sin6, sizeof(sin6)), NULL);
144*4d495c6eSApple OSS Distributions 
145*4d495c6eSApple OSS Distributions 	socklen = sizeof(sin6);
146*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(getsockname(listen_fd, (struct sockaddr *)&sin6, &socklen), NULL);
147*4d495c6eSApple OSS Distributions 
148*4d495c6eSApple OSS Distributions 	T_LOG("listening on port: %u", ntohs(sin6.sin6_port));
149*4d495c6eSApple OSS Distributions 	sin6_to->sin6_port = sin6.sin6_port;
150*4d495c6eSApple OSS Distributions 
151*4d495c6eSApple OSS Distributions 	(void)inet_ntop(AF_INET6, &sin6_to->sin6_addr, l_addr_str, sizeof(l_addr_str));
152*4d495c6eSApple OSS Distributions 	T_LOG("connect with sin6_len: %u sin6_family: %u sin6_port: %u sin6_addr: %s expected_error: %d",
153*4d495c6eSApple OSS Distributions 	    sin6_to->sin6_len, sin6_to->sin6_family, ntohs(sin6_to->sin6_port), l_addr_str, expected_error);
154*4d495c6eSApple OSS Distributions 
155*4d495c6eSApple OSS Distributions 	if (expected_error == 0) {
156*4d495c6eSApple OSS Distributions 		T_EXPECT_POSIX_SUCCESS(connect(client_fd, (struct sockaddr *)sin6_to, sizeof(struct sockaddr_in6)), NULL);
157*4d495c6eSApple OSS Distributions 
158*4d495c6eSApple OSS Distributions 		socklen = sizeof(sin6_local);
159*4d495c6eSApple OSS Distributions 		T_ASSERT_POSIX_SUCCESS(getsockname(client_fd, (struct sockaddr *)&sin6_local, &socklen), NULL);
160*4d495c6eSApple OSS Distributions 		(void)inet_ntop(AF_INET6, &sin6_local.sin6_addr, l_addr_str, sizeof(l_addr_str));
161*4d495c6eSApple OSS Distributions 
162*4d495c6eSApple OSS Distributions 		socklen = sizeof(sin6_peer);
163*4d495c6eSApple OSS Distributions 		T_ASSERT_POSIX_SUCCESS(getpeername(client_fd, (struct sockaddr *)&sin6_peer, &socklen), NULL);
164*4d495c6eSApple OSS Distributions 		(void)inet_ntop(AF_INET6, &sin6_peer.sin6_addr, f_addr_str, sizeof(f_addr_str));
165*4d495c6eSApple OSS Distributions 
166*4d495c6eSApple OSS Distributions 		T_LOG("connected from %s:%u to %s:%u",
167*4d495c6eSApple OSS Distributions 		    l_addr_str, ntohs(sin6_local.sin6_port),
168*4d495c6eSApple OSS Distributions 		    f_addr_str, ntohs(sin6_peer.sin6_port));
169*4d495c6eSApple OSS Distributions 	} else {
170*4d495c6eSApple OSS Distributions 		T_EXPECT_POSIX_FAILURE(connect(client_fd, (struct sockaddr *)sin6_to, sizeof(struct sockaddr_in6)), expected_error, NULL);
171*4d495c6eSApple OSS Distributions 	}
172*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(listen_fd), NULL);
173*4d495c6eSApple OSS Distributions }
174*4d495c6eSApple OSS Distributions 
175*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_loopback, "UDP bind with a IPv4 loopback address", T_META_TAG_VM_PREFERRED)
176*4d495c6eSApple OSS Distributions {
177*4d495c6eSApple OSS Distributions 	int s = -1;
178*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin = { 0 };
179*4d495c6eSApple OSS Distributions 
180*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
181*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "127.0.0.1", &sin.sin_addr), 1, NULL);
182*4d495c6eSApple OSS Distributions 
183*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
184*4d495c6eSApple OSS Distributions 
185*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin, sizeof(sin)), 0, NULL);
186*4d495c6eSApple OSS Distributions 
187*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
188*4d495c6eSApple OSS Distributions }
189*4d495c6eSApple OSS Distributions 
190*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_loopback, "UDP connect with a IPv4 loopback address", T_META_TAG_VM_PREFERRED)
191*4d495c6eSApple OSS Distributions {
192*4d495c6eSApple OSS Distributions 	int s = -1;
193*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin = { 0 };
194*4d495c6eSApple OSS Distributions 
195*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
196*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "127.0.0.1", &sin.sin_addr), 1, NULL);
197*4d495c6eSApple OSS Distributions 
198*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
199*4d495c6eSApple OSS Distributions 
200*4d495c6eSApple OSS Distributions 	udp_connect_v4(s, &sin, 0);
201*4d495c6eSApple OSS Distributions 
202*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
203*4d495c6eSApple OSS Distributions }
204*4d495c6eSApple OSS Distributions 
205*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_multicast, "UDP bind with a IPv4 multicast address", T_META_TAG_VM_PREFERRED)
206*4d495c6eSApple OSS Distributions {
207*4d495c6eSApple OSS Distributions 	int s = -1;
208*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin = { 0 };
209*4d495c6eSApple OSS Distributions 
210*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
211*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "224.0.0.1", &sin.sin_addr), 1, NULL);
212*4d495c6eSApple OSS Distributions 
213*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
214*4d495c6eSApple OSS Distributions 
215*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin, sizeof(sin)), NULL);
216*4d495c6eSApple OSS Distributions 
217*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
218*4d495c6eSApple OSS Distributions }
219*4d495c6eSApple OSS Distributions 
220*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_multicast, "UDP connect with an IPv4 multicast address", T_META_TAG_VM_PREFERRED)
221*4d495c6eSApple OSS Distributions {
222*4d495c6eSApple OSS Distributions 	if (!has_ipv4_default_route()) {
223*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv4 default route");
224*4d495c6eSApple OSS Distributions 	}
225*4d495c6eSApple OSS Distributions 
226*4d495c6eSApple OSS Distributions 	int s = -1;
227*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin = { 0 };
228*4d495c6eSApple OSS Distributions 
229*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
230*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "224.0.0.1", &sin.sin_addr), 1, NULL);
231*4d495c6eSApple OSS Distributions 
232*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
233*4d495c6eSApple OSS Distributions 
234*4d495c6eSApple OSS Distributions 	udp_connect_v4(s, &sin, 0);
235*4d495c6eSApple OSS Distributions 
236*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
237*4d495c6eSApple OSS Distributions }
238*4d495c6eSApple OSS Distributions 
239*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_broadcast, "UDP bind with the IPv4 broadcast address", T_META_TAG_VM_PREFERRED)
240*4d495c6eSApple OSS Distributions {
241*4d495c6eSApple OSS Distributions 	int s = -1;
242*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin = { 0 };
243*4d495c6eSApple OSS Distributions 
244*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
245*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "255.255.255.255", &sin.sin_addr), 1, NULL);
246*4d495c6eSApple OSS Distributions 
247*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
248*4d495c6eSApple OSS Distributions 
249*4d495c6eSApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin, sizeof(sin)), EADDRNOTAVAIL, NULL);
250*4d495c6eSApple OSS Distributions 
251*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
252*4d495c6eSApple OSS Distributions }
253*4d495c6eSApple OSS Distributions 
254*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_broadcast, "UDP connect with the IPv4 broadcast address", T_META_TAG_VM_PREFERRED)
255*4d495c6eSApple OSS Distributions {
256*4d495c6eSApple OSS Distributions 	if (!has_ipv4_default_route()) {
257*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv4 default route");
258*4d495c6eSApple OSS Distributions 	}
259*4d495c6eSApple OSS Distributions 
260*4d495c6eSApple OSS Distributions 	int s = -1;
261*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin = { 0 };
262*4d495c6eSApple OSS Distributions 
263*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
264*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "255.255.255.255", &sin.sin_addr), 1, NULL);
265*4d495c6eSApple OSS Distributions 
266*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
267*4d495c6eSApple OSS Distributions 
268*4d495c6eSApple OSS Distributions 	udp_connect_v4(s, &sin, 0);
269*4d495c6eSApple OSS Distributions 
270*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
271*4d495c6eSApple OSS Distributions }
272*4d495c6eSApple OSS Distributions 
273*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_null, "UDP bind with the null IPv4 address", T_META_TAG_VM_PREFERRED)
274*4d495c6eSApple OSS Distributions {
275*4d495c6eSApple OSS Distributions 	int s = -1;
276*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin = { 0 };
277*4d495c6eSApple OSS Distributions 
278*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
279*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "0.0.0.0", &sin.sin_addr), 1, NULL);
280*4d495c6eSApple OSS Distributions 
281*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
282*4d495c6eSApple OSS Distributions 
283*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin, sizeof(sin)), NULL);
284*4d495c6eSApple OSS Distributions 
285*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
286*4d495c6eSApple OSS Distributions }
287*4d495c6eSApple OSS Distributions 
288*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_null, "UDP connect with the null IPv4 address", T_META_TAG_VM_PREFERRED)
289*4d495c6eSApple OSS Distributions {
290*4d495c6eSApple OSS Distributions 	if (!has_ipv4_default_route()) {
291*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv4 default route");
292*4d495c6eSApple OSS Distributions 	}
293*4d495c6eSApple OSS Distributions 
294*4d495c6eSApple OSS Distributions 	int s = -1;
295*4d495c6eSApple OSS Distributions 	struct sockaddr_in sin = { 0 };
296*4d495c6eSApple OSS Distributions 
297*4d495c6eSApple OSS Distributions 	init_sin_address(&sin);
298*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET, "0.0.0.0", &sin.sin_addr), 1, NULL);
299*4d495c6eSApple OSS Distributions 
300*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP), NULL);
301*4d495c6eSApple OSS Distributions 
302*4d495c6eSApple OSS Distributions 	udp_connect_v4(s, &sin, 0);
303*4d495c6eSApple OSS Distributions 
304*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
305*4d495c6eSApple OSS Distributions }
306*4d495c6eSApple OSS Distributions 
307*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv6_loopback, "UDP bind with the IPv6 loopback address", T_META_TAG_VM_PREFERRED)
308*4d495c6eSApple OSS Distributions {
309*4d495c6eSApple OSS Distributions 	int s = -1;
310*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
311*4d495c6eSApple OSS Distributions 
312*4d495c6eSApple OSS Distributions 	sin6.sin6_scope_id = if_nametoindex("lo0");
313*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::1", &sin6.sin6_addr), 1, NULL);
314*4d495c6eSApple OSS Distributions 
315*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
316*4d495c6eSApple OSS Distributions 
317*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
318*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), NULL);
319*4d495c6eSApple OSS Distributions 
320*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
321*4d495c6eSApple OSS Distributions }
322*4d495c6eSApple OSS Distributions 
323*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv6_loopback, "UDP connect with the IPv6 loopback address", T_META_TAG_VM_PREFERRED)
324*4d495c6eSApple OSS Distributions {
325*4d495c6eSApple OSS Distributions 	int s = -1;
326*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
327*4d495c6eSApple OSS Distributions 
328*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
329*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::1", &sin6.sin6_addr), 1, NULL);
330*4d495c6eSApple OSS Distributions 
331*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
332*4d495c6eSApple OSS Distributions 
333*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
334*4d495c6eSApple OSS Distributions 
335*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
336*4d495c6eSApple OSS Distributions }
337*4d495c6eSApple OSS Distributions 
338*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv6_multicast, "UDP bind with a IPv6 multicast address", T_META_TAG_VM_PREFERRED)
339*4d495c6eSApple OSS Distributions {
340*4d495c6eSApple OSS Distributions 	int s = -1;
341*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
342*4d495c6eSApple OSS Distributions 
343*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
344*4d495c6eSApple OSS Distributions 	sin6.sin6_scope_id = if_nametoindex("lo0");
345*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "ff01::1", &sin6.sin6_addr), 1, NULL);
346*4d495c6eSApple OSS Distributions 
347*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
348*4d495c6eSApple OSS Distributions 
349*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), NULL);
350*4d495c6eSApple OSS Distributions 
351*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
352*4d495c6eSApple OSS Distributions }
353*4d495c6eSApple OSS Distributions 
354*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv6_multicast, "UDP connect with a IPv6 multicast address", T_META_TAG_VM_PREFERRED)
355*4d495c6eSApple OSS Distributions {
356*4d495c6eSApple OSS Distributions 	int s = -1;
357*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
358*4d495c6eSApple OSS Distributions 
359*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
360*4d495c6eSApple OSS Distributions 	sin6.sin6_scope_id = if_nametoindex("lo0");
361*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "ff01::1", &sin6.sin6_addr), 1, NULL);
362*4d495c6eSApple OSS Distributions 
363*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
364*4d495c6eSApple OSS Distributions 
365*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
366*4d495c6eSApple OSS Distributions 
367*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
368*4d495c6eSApple OSS Distributions }
369*4d495c6eSApple OSS Distributions 
370*4d495c6eSApple OSS Distributions T_DECL(udp_bind_null_ipv6, "UDP bind with the IPv6 null address", T_META_TAG_VM_PREFERRED)
371*4d495c6eSApple OSS Distributions {
372*4d495c6eSApple OSS Distributions 	int s = -1;
373*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
374*4d495c6eSApple OSS Distributions 
375*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
376*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::", &sin6.sin6_addr), 1, NULL);
377*4d495c6eSApple OSS Distributions 
378*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
379*4d495c6eSApple OSS Distributions 
380*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), NULL);
381*4d495c6eSApple OSS Distributions 
382*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
383*4d495c6eSApple OSS Distributions }
384*4d495c6eSApple OSS Distributions 
385*4d495c6eSApple OSS Distributions T_DECL(udp_connect_null_ipv6, "UDP connect with the IPv6 null address", T_META_TAG_VM_PREFERRED)
386*4d495c6eSApple OSS Distributions {
387*4d495c6eSApple OSS Distributions 	int s = -1;
388*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
389*4d495c6eSApple OSS Distributions 
390*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
391*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::", &sin6.sin6_addr), 1, NULL);
392*4d495c6eSApple OSS Distributions 
393*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
394*4d495c6eSApple OSS Distributions 
395*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
396*4d495c6eSApple OSS Distributions 
397*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
398*4d495c6eSApple OSS Distributions }
399*4d495c6eSApple OSS Distributions 
400*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_multicast_mapped_ipv6, "UDP bind with IPv4 multicast mapped IPv6 address", T_META_TAG_VM_PREFERRED)
401*4d495c6eSApple OSS Distributions {
402*4d495c6eSApple OSS Distributions 	int s = -1;
403*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
404*4d495c6eSApple OSS Distributions 
405*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
406*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:224.0.0.1", &sin6.sin6_addr), 1, NULL);
407*4d495c6eSApple OSS Distributions 
408*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
409*4d495c6eSApple OSS Distributions 
410*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), NULL);
411*4d495c6eSApple OSS Distributions 
412*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
413*4d495c6eSApple OSS Distributions }
414*4d495c6eSApple OSS Distributions 
415*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_multicast_mapped_ipv6, "UDP connect with IPv4 multicast mapped IPv6 address", T_META_TAG_VM_PREFERRED)
416*4d495c6eSApple OSS Distributions {
417*4d495c6eSApple OSS Distributions 	if (!has_ipv4_default_route()) {
418*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv4 default route");
419*4d495c6eSApple OSS Distributions 	}
420*4d495c6eSApple OSS Distributions 
421*4d495c6eSApple OSS Distributions 	int s = -1;
422*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
423*4d495c6eSApple OSS Distributions 
424*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
425*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:224.0.0.1", &sin6.sin6_addr), 1, NULL);
426*4d495c6eSApple OSS Distributions 
427*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
428*4d495c6eSApple OSS Distributions 
429*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
430*4d495c6eSApple OSS Distributions 
431*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
432*4d495c6eSApple OSS Distributions }
433*4d495c6eSApple OSS Distributions 
434*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_broadcast_mapped_ipv6, "UDP bind with IPv4 broadcast mapped IPv6 address", T_META_TAG_VM_PREFERRED)
435*4d495c6eSApple OSS Distributions {
436*4d495c6eSApple OSS Distributions 	int s = -1;
437*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
438*4d495c6eSApple OSS Distributions 
439*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
440*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:255.255.255.255", &sin6.sin6_addr), 1, NULL);
441*4d495c6eSApple OSS Distributions 
442*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
443*4d495c6eSApple OSS Distributions 
444*4d495c6eSApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), EADDRNOTAVAIL, NULL);
445*4d495c6eSApple OSS Distributions 
446*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
447*4d495c6eSApple OSS Distributions }
448*4d495c6eSApple OSS Distributions 
449*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_broadcast_mapped_ipv6, "UDP connect with IPv4 broadcast mapped IPv6 address", T_META_TAG_VM_PREFERRED)
450*4d495c6eSApple OSS Distributions {
451*4d495c6eSApple OSS Distributions 	if (!has_ipv4_default_route()) {
452*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv4 default route");
453*4d495c6eSApple OSS Distributions 	}
454*4d495c6eSApple OSS Distributions 
455*4d495c6eSApple OSS Distributions 	int s = -1;
456*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
457*4d495c6eSApple OSS Distributions 
458*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
459*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:255.255.255.255", &sin6.sin6_addr), 1, NULL);
460*4d495c6eSApple OSS Distributions 
461*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
462*4d495c6eSApple OSS Distributions 
463*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
464*4d495c6eSApple OSS Distributions 
465*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
466*4d495c6eSApple OSS Distributions }
467*4d495c6eSApple OSS Distributions 
468*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_null_mapped_ipv6, "UDP bind with IPv4 null mapped IPv6 address", T_META_TAG_VM_PREFERRED)
469*4d495c6eSApple OSS Distributions {
470*4d495c6eSApple OSS Distributions 	int s = -1;
471*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
472*4d495c6eSApple OSS Distributions 
473*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
474*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:0.0.0.0", &sin6.sin6_addr), 1, NULL);
475*4d495c6eSApple OSS Distributions 
476*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
477*4d495c6eSApple OSS Distributions 
478*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
479*4d495c6eSApple OSS Distributions 
480*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
481*4d495c6eSApple OSS Distributions }
482*4d495c6eSApple OSS Distributions 
483*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_null_mapped_ipv6, "UDP connect with IPv4 null mapped IPv6 address", T_META_TAG_VM_PREFERRED)
484*4d495c6eSApple OSS Distributions {
485*4d495c6eSApple OSS Distributions 	if (!has_ipv4_default_route()) {
486*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv4 default route");
487*4d495c6eSApple OSS Distributions 	}
488*4d495c6eSApple OSS Distributions 
489*4d495c6eSApple OSS Distributions 	int s = -1;
490*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
491*4d495c6eSApple OSS Distributions 
492*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
493*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:0.0.0.0", &sin6.sin6_addr), 1, NULL);
494*4d495c6eSApple OSS Distributions 
495*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
496*4d495c6eSApple OSS Distributions 
497*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
498*4d495c6eSApple OSS Distributions 
499*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
500*4d495c6eSApple OSS Distributions }
501*4d495c6eSApple OSS Distributions 
502*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_multicast_compatible_ipv6, "UDP bind with IPv4 multicast compatible IPv6 address", T_META_TAG_VM_PREFERRED)
503*4d495c6eSApple OSS Distributions {
504*4d495c6eSApple OSS Distributions 	int s = -1;
505*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
506*4d495c6eSApple OSS Distributions 
507*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
508*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::224.0.0.1", &sin6.sin6_addr), 1, NULL);
509*4d495c6eSApple OSS Distributions 
510*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
511*4d495c6eSApple OSS Distributions 
512*4d495c6eSApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), EADDRNOTAVAIL, NULL);
513*4d495c6eSApple OSS Distributions 
514*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
515*4d495c6eSApple OSS Distributions }
516*4d495c6eSApple OSS Distributions 
517*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_multicast_compatible_ipv6, "UDP connect with IPv4 multicast compatible IPv6 address", T_META_TAG_VM_PREFERRED)
518*4d495c6eSApple OSS Distributions {
519*4d495c6eSApple OSS Distributions 	if (!has_ipv6_default_route()) {
520*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv6 default route");
521*4d495c6eSApple OSS Distributions 	}
522*4d495c6eSApple OSS Distributions 
523*4d495c6eSApple OSS Distributions 	int s = -1;
524*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
525*4d495c6eSApple OSS Distributions 
526*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
527*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::224.0.0.1", &sin6.sin6_addr), 1, NULL);
528*4d495c6eSApple OSS Distributions 
529*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
530*4d495c6eSApple OSS Distributions 
531*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
532*4d495c6eSApple OSS Distributions 
533*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
534*4d495c6eSApple OSS Distributions }
535*4d495c6eSApple OSS Distributions 
536*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_broadcast_compatible_ipv6, "UDP bind with IPv4 broadcast compatible IPv6 address", T_META_TAG_VM_PREFERRED)
537*4d495c6eSApple OSS Distributions {
538*4d495c6eSApple OSS Distributions 	int s = -1;
539*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
540*4d495c6eSApple OSS Distributions 
541*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
542*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::255.255.255.255", &sin6.sin6_addr), 1, NULL);
543*4d495c6eSApple OSS Distributions 
544*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
545*4d495c6eSApple OSS Distributions 
546*4d495c6eSApple OSS Distributions 	T_EXPECT_POSIX_FAILURE(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), EADDRNOTAVAIL, NULL);
547*4d495c6eSApple OSS Distributions 
548*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
549*4d495c6eSApple OSS Distributions }
550*4d495c6eSApple OSS Distributions 
551*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_broadcast_compatible_ipv6, "UDP connect with IPv4 broadcast compatible IPv6 address", T_META_TAG_VM_PREFERRED)
552*4d495c6eSApple OSS Distributions {
553*4d495c6eSApple OSS Distributions 	if (!has_ipv6_default_route()) {
554*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv6 default route");
555*4d495c6eSApple OSS Distributions 	}
556*4d495c6eSApple OSS Distributions 
557*4d495c6eSApple OSS Distributions 	int s = -1;
558*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
559*4d495c6eSApple OSS Distributions 
560*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
561*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::255.255.255.255", &sin6.sin6_addr), 1, NULL);
562*4d495c6eSApple OSS Distributions 
563*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
564*4d495c6eSApple OSS Distributions 
565*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
566*4d495c6eSApple OSS Distributions 
567*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
568*4d495c6eSApple OSS Distributions }
569*4d495c6eSApple OSS Distributions 
570*4d495c6eSApple OSS Distributions T_DECL(udp_bind_ipv4_null_compatible_ipv6, "UDP bind with IPv4 null compatible IPv6 address", T_META_TAG_VM_PREFERRED)
571*4d495c6eSApple OSS Distributions {
572*4d495c6eSApple OSS Distributions 	int s = -1;
573*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
574*4d495c6eSApple OSS Distributions 
575*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
576*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::0.0.0.0", &sin6.sin6_addr), 1, NULL);
577*4d495c6eSApple OSS Distributions 
578*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
579*4d495c6eSApple OSS Distributions 
580*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(s, (const struct sockaddr *)&sin6, sizeof(sin6)), NULL);
581*4d495c6eSApple OSS Distributions 
582*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
583*4d495c6eSApple OSS Distributions }
584*4d495c6eSApple OSS Distributions 
585*4d495c6eSApple OSS Distributions T_DECL(udp_connect_ipv4_null_compatible_ipv6, "UDP connect with IPv4 null compatible IPv6 address", T_META_TAG_VM_PREFERRED)
586*4d495c6eSApple OSS Distributions {
587*4d495c6eSApple OSS Distributions 	if (!has_ipv6_default_route()) {
588*4d495c6eSApple OSS Distributions 		T_SKIP("test require IPv6 default route");
589*4d495c6eSApple OSS Distributions 	}
590*4d495c6eSApple OSS Distributions 
591*4d495c6eSApple OSS Distributions 	int s = -1;
592*4d495c6eSApple OSS Distributions 	struct sockaddr_in6 sin6 = { 0 };
593*4d495c6eSApple OSS Distributions 
594*4d495c6eSApple OSS Distributions 	init_sin6_address(&sin6);
595*4d495c6eSApple OSS Distributions 	T_ASSERT_EQ(inet_pton(AF_INET6, "::0.0.0.0", &sin6.sin6_addr), 1, NULL);
596*4d495c6eSApple OSS Distributions 
597*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_DGRAM, IPPROTO_UDP), NULL);
598*4d495c6eSApple OSS Distributions 
599*4d495c6eSApple OSS Distributions 	udp_connect_v6(s, &sin6, 0);
600*4d495c6eSApple OSS Distributions 
601*4d495c6eSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(s), NULL);
602*4d495c6eSApple OSS Distributions }
603