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