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