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 #include <net/if.h>
32*4d495c6eSApple OSS Distributions #include <netinet/in.h>
33*4d495c6eSApple OSS Distributions #include <netinet/tcp.h>
34*4d495c6eSApple OSS Distributions #include <arpa/inet.h>
35*4d495c6eSApple OSS Distributions
36*4d495c6eSApple OSS Distributions #include <darwintest.h>
37*4d495c6eSApple OSS Distributions #include <string.h>
38*4d495c6eSApple OSS Distributions #include <unistd.h>
39*4d495c6eSApple OSS Distributions
40*4d495c6eSApple OSS Distributions T_GLOBAL_META(T_META_NAMESPACE("xnu.net"));
41*4d495c6eSApple OSS Distributions
42*4d495c6eSApple OSS Distributions #define MAX_IPv6_STR_LEN 64
43*4d495c6eSApple OSS Distributions
44*4d495c6eSApple OSS Distributions static char l_addr_str[MAX_IPv6_STR_LEN];
45*4d495c6eSApple OSS Distributions static char f_addr_str[MAX_IPv6_STR_LEN];
46*4d495c6eSApple OSS Distributions
47*4d495c6eSApple OSS Distributions const struct in6_addr in6addr_any = IN6ADDR_ANY_INIT;
48*4d495c6eSApple OSS Distributions #define s6_addr32 __u6_addr.__u6_addr32
49*4d495c6eSApple OSS Distributions
50*4d495c6eSApple OSS Distributions static void
init_sin_address(struct sockaddr_in * sin)51*4d495c6eSApple OSS Distributions init_sin_address(struct sockaddr_in *sin)
52*4d495c6eSApple OSS Distributions {
53*4d495c6eSApple OSS Distributions memset(sin, 0, sizeof(struct sockaddr_in));
54*4d495c6eSApple OSS Distributions sin->sin_len = sizeof(struct sockaddr_in);
55*4d495c6eSApple OSS Distributions sin->sin_family = AF_INET;
56*4d495c6eSApple OSS Distributions }
57*4d495c6eSApple OSS Distributions
58*4d495c6eSApple OSS Distributions static void
init_sin6_address(struct sockaddr_in6 * sin6)59*4d495c6eSApple OSS Distributions init_sin6_address(struct sockaddr_in6 *sin6)
60*4d495c6eSApple OSS Distributions {
61*4d495c6eSApple OSS Distributions memset(sin6, 0, sizeof(struct sockaddr_in6));
62*4d495c6eSApple OSS Distributions sin6->sin6_len = sizeof(struct sockaddr_in6);
63*4d495c6eSApple OSS Distributions sin6->sin6_family = AF_INET6;
64*4d495c6eSApple OSS Distributions }
65*4d495c6eSApple OSS Distributions
66*4d495c6eSApple OSS Distributions static int
tcp_send_implied_connect_v4(int client_fd,struct sockaddr_in * sin_to,int expected_error)67*4d495c6eSApple OSS Distributions tcp_send_implied_connect_v4(int client_fd, struct sockaddr_in *sin_to, int expected_error)
68*4d495c6eSApple OSS Distributions {
69*4d495c6eSApple OSS Distributions int listen_fd = -1;
70*4d495c6eSApple OSS Distributions socklen_t socklen;
71*4d495c6eSApple OSS Distributions int val = 10;
72*4d495c6eSApple OSS Distributions struct sockaddr_in sin_local = {};
73*4d495c6eSApple OSS Distributions struct sockaddr_in sin_peer = {};
74*4d495c6eSApple OSS Distributions struct sockaddr_in sin;
75*4d495c6eSApple OSS Distributions
76*4d495c6eSApple OSS Distributions init_sin_address(&sin);
77*4d495c6eSApple OSS Distributions init_sin_address(&sin_local);
78*4d495c6eSApple OSS Distributions init_sin_address(&sin_peer);
79*4d495c6eSApple OSS Distributions
80*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(listen_fd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
81*4d495c6eSApple OSS Distributions
82*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(bind(listen_fd, (struct sockaddr *)&sin, sizeof(sin)), NULL);
83*4d495c6eSApple OSS Distributions
84*4d495c6eSApple OSS Distributions socklen = sizeof(sin);
85*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(getsockname(listen_fd, (struct sockaddr *)&sin, &socklen), NULL);
86*4d495c6eSApple OSS Distributions
87*4d495c6eSApple OSS Distributions T_LOG("listening on port: %u", ntohs(sin.sin_port));
88*4d495c6eSApple OSS Distributions sin_to->sin_port = sin.sin_port;
89*4d495c6eSApple OSS Distributions
90*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(listen(listen_fd, 10), NULL);
91*4d495c6eSApple OSS Distributions
92*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(setsockopt(client_fd, IPPROTO_TCP, TCP_CONNECTIONTIMEOUT, &val, sizeof(val)), NULL);
93*4d495c6eSApple OSS Distributions
94*4d495c6eSApple OSS Distributions T_LOG("sendmsg with sin_len: %u sin_family: %u sin_port: %u sin_addr: 0x%08x expected_error: %d",
95*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);
96*4d495c6eSApple OSS Distributions
97*4d495c6eSApple OSS Distributions struct iovec iovec = { .iov_base = "", .iov_len = 0 };
98*4d495c6eSApple OSS Distributions struct msghdr msg = {};
99*4d495c6eSApple OSS Distributions struct cmsghdr *cmsghdrp;
100*4d495c6eSApple OSS Distributions char buf[CMSG_SPACE(sizeof(int))];
101*4d495c6eSApple OSS Distributions
102*4d495c6eSApple OSS Distributions msg.msg_name = sin_to;
103*4d495c6eSApple OSS Distributions msg.msg_namelen = sin_to->sin_len;
104*4d495c6eSApple OSS Distributions msg.msg_iov = &iovec;
105*4d495c6eSApple OSS Distributions msg.msg_iovlen = 1;
106*4d495c6eSApple OSS Distributions msg.msg_control = buf;
107*4d495c6eSApple OSS Distributions msg.msg_controllen = CMSG_SPACE(sizeof(int));
108*4d495c6eSApple OSS Distributions
109*4d495c6eSApple OSS Distributions cmsghdrp = CMSG_FIRSTHDR(&msg);
110*4d495c6eSApple OSS Distributions cmsghdrp->cmsg_len = CMSG_LEN(sizeof(int));
111*4d495c6eSApple OSS Distributions cmsghdrp->cmsg_level = SOL_SOCKET;
112*4d495c6eSApple OSS Distributions cmsghdrp->cmsg_type = SCM_RIGHTS;
113*4d495c6eSApple OSS Distributions
114*4d495c6eSApple OSS Distributions memcpy(CMSG_DATA(cmsghdrp), &client_fd, sizeof(client_fd));
115*4d495c6eSApple OSS Distributions
116*4d495c6eSApple OSS Distributions ssize_t retval = sendmsg(client_fd, &msg, 0);
117*4d495c6eSApple OSS Distributions
118*4d495c6eSApple OSS Distributions if (expected_error == 0) {
119*4d495c6eSApple OSS Distributions T_EXPECT_POSIX_SUCCESS(retval, "sendmsg(client_fd, &msg, 0)");
120*4d495c6eSApple OSS Distributions } else {
121*4d495c6eSApple OSS Distributions T_EXPECT_POSIX_FAILURE(retval, expected_error, "sendmsg(client_fd, &msg, 0)");
122*4d495c6eSApple OSS Distributions }
123*4d495c6eSApple OSS Distributions
124*4d495c6eSApple OSS Distributions if (retval == 0) {
125*4d495c6eSApple OSS Distributions socklen = sizeof(sin_local);
126*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(getsockname(client_fd, (struct sockaddr *)&sin_local, &socklen), NULL);
127*4d495c6eSApple OSS Distributions (void)inet_ntop(AF_INET, &sin_local.sin_addr, l_addr_str, sizeof(l_addr_str));
128*4d495c6eSApple OSS Distributions
129*4d495c6eSApple OSS Distributions socklen = sizeof(sin_peer);
130*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(getpeername(client_fd, (struct sockaddr *)&sin_peer, &socklen), NULL);
131*4d495c6eSApple OSS Distributions (void)inet_ntop(AF_INET, &sin_peer.sin_addr, f_addr_str, sizeof(f_addr_str));
132*4d495c6eSApple OSS Distributions
133*4d495c6eSApple OSS Distributions T_LOG("connected from %s:%u to %s:%u",
134*4d495c6eSApple OSS Distributions l_addr_str, ntohs(sin_local.sin_port),
135*4d495c6eSApple OSS Distributions f_addr_str, ntohs(sin_peer.sin_port));
136*4d495c6eSApple OSS Distributions }
137*4d495c6eSApple OSS Distributions
138*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(listen_fd), NULL);
139*4d495c6eSApple OSS Distributions
140*4d495c6eSApple OSS Distributions return 0;
141*4d495c6eSApple OSS Distributions }
142*4d495c6eSApple OSS Distributions
143*4d495c6eSApple OSS Distributions static int
tcp_send_implied_connect_v6(int client_fd,struct sockaddr_in6 * sin6_to,int expected_error)144*4d495c6eSApple OSS Distributions tcp_send_implied_connect_v6(int client_fd, struct sockaddr_in6 *sin6_to, int expected_error)
145*4d495c6eSApple OSS Distributions {
146*4d495c6eSApple OSS Distributions int listen_fd = -1;
147*4d495c6eSApple OSS Distributions socklen_t socklen;
148*4d495c6eSApple OSS Distributions int off = 0;
149*4d495c6eSApple OSS Distributions int val = 10;
150*4d495c6eSApple OSS Distributions struct iovec iovec = { .iov_base = "", .iov_len = 0 };
151*4d495c6eSApple OSS Distributions struct msghdr msg = {};
152*4d495c6eSApple OSS Distributions struct cmsghdr *cmsghdrp;
153*4d495c6eSApple OSS Distributions char buf[CMSG_SPACE(sizeof(int))];
154*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6_local = {};
155*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6_peer = {};
156*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6;
157*4d495c6eSApple OSS Distributions
158*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
159*4d495c6eSApple OSS Distributions init_sin6_address(&sin6_local);
160*4d495c6eSApple OSS Distributions init_sin6_address(&sin6_peer);
161*4d495c6eSApple OSS Distributions
162*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(listen_fd = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
163*4d495c6eSApple OSS Distributions
164*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(setsockopt(listen_fd, IPPROTO_IPV6, IPV6_V6ONLY, &off, sizeof(off)), NULL);
165*4d495c6eSApple OSS Distributions
166*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(bind(listen_fd, (struct sockaddr *)&sin6, sizeof(sin6)), NULL);
167*4d495c6eSApple OSS Distributions
168*4d495c6eSApple OSS Distributions socklen = sizeof(sin6);
169*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(getsockname(listen_fd, (struct sockaddr *)&sin6, &socklen), NULL);
170*4d495c6eSApple OSS Distributions
171*4d495c6eSApple OSS Distributions T_LOG("listening on port: %u", ntohs(sin6.sin6_port));
172*4d495c6eSApple OSS Distributions sin6_to->sin6_port = sin6.sin6_port;
173*4d495c6eSApple OSS Distributions
174*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(listen(listen_fd, 10), NULL);
175*4d495c6eSApple OSS Distributions
176*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(setsockopt(client_fd, IPPROTO_TCP, TCP_CONNECTIONTIMEOUT, &val, sizeof(val)), NULL);
177*4d495c6eSApple OSS Distributions
178*4d495c6eSApple OSS Distributions msg.msg_name = sin6_to;
179*4d495c6eSApple OSS Distributions msg.msg_namelen = sin6_to->sin6_len;
180*4d495c6eSApple OSS Distributions msg.msg_iov = &iovec;
181*4d495c6eSApple OSS Distributions msg.msg_iovlen = 1;
182*4d495c6eSApple OSS Distributions msg.msg_control = buf;
183*4d495c6eSApple OSS Distributions msg.msg_controllen = CMSG_SPACE(sizeof(int));
184*4d495c6eSApple OSS Distributions
185*4d495c6eSApple OSS Distributions cmsghdrp = CMSG_FIRSTHDR(&msg);
186*4d495c6eSApple OSS Distributions cmsghdrp->cmsg_len = CMSG_LEN(sizeof(int));
187*4d495c6eSApple OSS Distributions cmsghdrp->cmsg_level = SOL_SOCKET;
188*4d495c6eSApple OSS Distributions cmsghdrp->cmsg_type = SCM_RIGHTS;
189*4d495c6eSApple OSS Distributions
190*4d495c6eSApple OSS Distributions memcpy(CMSG_DATA(cmsghdrp), &client_fd, sizeof(client_fd));
191*4d495c6eSApple OSS Distributions
192*4d495c6eSApple OSS Distributions (void)inet_ntop(AF_INET6, &sin6_to->sin6_addr, l_addr_str, sizeof(l_addr_str));
193*4d495c6eSApple OSS Distributions
194*4d495c6eSApple OSS Distributions T_LOG("sendmsg with sin6_len: %u sin6_family: %u sin6_port: %u sin6_addr: %s expected_error: %d",
195*4d495c6eSApple OSS Distributions sin6_to->sin6_len, sin6_to->sin6_family, ntohs(sin6_to->sin6_port), l_addr_str, expected_error);
196*4d495c6eSApple OSS Distributions
197*4d495c6eSApple OSS Distributions ssize_t retval = sendmsg(client_fd, &msg, 0);
198*4d495c6eSApple OSS Distributions
199*4d495c6eSApple OSS Distributions if (expected_error == 0) {
200*4d495c6eSApple OSS Distributions T_EXPECT_POSIX_SUCCESS(retval, "sendmsg(client_fd, &msg, 0)");
201*4d495c6eSApple OSS Distributions } else {
202*4d495c6eSApple OSS Distributions T_EXPECT_POSIX_FAILURE(retval, expected_error, "sendmsg(client_fd, &msg, 0)");
203*4d495c6eSApple OSS Distributions }
204*4d495c6eSApple OSS Distributions
205*4d495c6eSApple OSS Distributions if (retval == 0) {
206*4d495c6eSApple OSS Distributions socklen = sizeof(sin6_local);
207*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(getsockname(client_fd, (struct sockaddr *)&sin6_local, &socklen), NULL);
208*4d495c6eSApple OSS Distributions (void)inet_ntop(AF_INET6, &sin6_local.sin6_addr, l_addr_str, sizeof(l_addr_str));
209*4d495c6eSApple OSS Distributions
210*4d495c6eSApple OSS Distributions socklen = sizeof(sin6_peer);
211*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(getpeername(client_fd, (struct sockaddr *)&sin6_peer, &socklen), NULL);
212*4d495c6eSApple OSS Distributions (void)inet_ntop(AF_INET6, &sin6_peer.sin6_addr, f_addr_str, sizeof(f_addr_str));
213*4d495c6eSApple OSS Distributions
214*4d495c6eSApple OSS Distributions T_LOG("connected from %s:%u to %s:%u",
215*4d495c6eSApple OSS Distributions l_addr_str, ntohs(sin6_local.sin6_port),
216*4d495c6eSApple OSS Distributions f_addr_str, ntohs(sin6_peer.sin6_port));
217*4d495c6eSApple OSS Distributions }
218*4d495c6eSApple OSS Distributions
219*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(listen_fd), NULL);
220*4d495c6eSApple OSS Distributions
221*4d495c6eSApple OSS Distributions return 0;
222*4d495c6eSApple OSS Distributions }
223*4d495c6eSApple OSS Distributions
224*4d495c6eSApple OSS Distributions
225*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_loopback, "TCP send implied connect with a IPv4 loopback address", T_META_TAG_VM_PREFERRED)
226*4d495c6eSApple OSS Distributions {
227*4d495c6eSApple OSS Distributions int s = -1;
228*4d495c6eSApple OSS Distributions struct sockaddr_in sin = {};
229*4d495c6eSApple OSS Distributions
230*4d495c6eSApple OSS Distributions init_sin_address(&sin);
231*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET, "127.0.0.1", &sin.sin_addr), 1, NULL);
232*4d495c6eSApple OSS Distributions
233*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
234*4d495c6eSApple OSS Distributions
235*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v4(s, &sin, 0), NULL);
236*4d495c6eSApple OSS Distributions
237*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
238*4d495c6eSApple OSS Distributions }
239*4d495c6eSApple OSS Distributions
240*4d495c6eSApple OSS Distributions
241*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_multicast, "TCP send implied connect with an IPv4 multicast address", T_META_TAG_VM_PREFERRED)
242*4d495c6eSApple OSS Distributions {
243*4d495c6eSApple OSS Distributions int s = -1;
244*4d495c6eSApple OSS Distributions struct sockaddr_in sin = {};
245*4d495c6eSApple OSS Distributions
246*4d495c6eSApple OSS Distributions init_sin_address(&sin);
247*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET, "224.0.0.1", &sin.sin_addr), 1, NULL);
248*4d495c6eSApple OSS Distributions
249*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
250*4d495c6eSApple OSS Distributions
251*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v4(s, &sin, EAFNOSUPPORT), NULL);
252*4d495c6eSApple OSS Distributions
253*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
254*4d495c6eSApple OSS Distributions }
255*4d495c6eSApple OSS Distributions
256*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_broadcast, "TCP send implied connect with the IPv4 broadcast address", T_META_TAG_VM_PREFERRED)
257*4d495c6eSApple OSS Distributions {
258*4d495c6eSApple OSS Distributions int s = -1;
259*4d495c6eSApple OSS Distributions struct sockaddr_in sin = {};
260*4d495c6eSApple OSS Distributions
261*4d495c6eSApple OSS Distributions init_sin_address(&sin);
262*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET, "255.255.255.255", &sin.sin_addr), 1, NULL);
263*4d495c6eSApple OSS Distributions
264*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
265*4d495c6eSApple OSS Distributions
266*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v4(s, &sin, EAFNOSUPPORT), NULL);
267*4d495c6eSApple OSS Distributions
268*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
269*4d495c6eSApple OSS Distributions }
270*4d495c6eSApple OSS Distributions
271*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_null, "TCP send implied connect with the null IPv4 address", T_META_TAG_VM_PREFERRED)
272*4d495c6eSApple OSS Distributions {
273*4d495c6eSApple OSS Distributions int s = -1;
274*4d495c6eSApple OSS Distributions struct sockaddr_in sin = {};
275*4d495c6eSApple OSS Distributions
276*4d495c6eSApple OSS Distributions init_sin_address(&sin);
277*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET, "0.0.0.0", &sin.sin_addr), 1, NULL);
278*4d495c6eSApple OSS Distributions
279*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP), NULL);
280*4d495c6eSApple OSS Distributions
281*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v4(s, &sin, 0), NULL);
282*4d495c6eSApple OSS Distributions
283*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
284*4d495c6eSApple OSS Distributions }
285*4d495c6eSApple OSS Distributions
286*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv6_loopback, "TCP send implied connect with the IPv6 loopback address", T_META_TAG_VM_PREFERRED)
287*4d495c6eSApple OSS Distributions {
288*4d495c6eSApple OSS Distributions int s = -1;
289*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
290*4d495c6eSApple OSS Distributions
291*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
292*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "::1", &sin6.sin6_addr), 1, NULL);
293*4d495c6eSApple OSS Distributions
294*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
295*4d495c6eSApple OSS Distributions
296*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, 0), NULL);
297*4d495c6eSApple OSS Distributions
298*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
299*4d495c6eSApple OSS Distributions }
300*4d495c6eSApple OSS Distributions
301*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv6_multicast, "TCP send implied connect with a IPv6 multicast address", T_META_TAG_VM_PREFERRED)
302*4d495c6eSApple OSS Distributions {
303*4d495c6eSApple OSS Distributions int s = -1;
304*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
305*4d495c6eSApple OSS Distributions
306*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
307*4d495c6eSApple OSS Distributions sin6.sin6_scope_id = if_nametoindex("lo0");
308*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "ff01::1", &sin6.sin6_addr), 1, NULL);
309*4d495c6eSApple OSS Distributions
310*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
311*4d495c6eSApple OSS Distributions
312*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
313*4d495c6eSApple OSS Distributions
314*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
315*4d495c6eSApple OSS Distributions }
316*4d495c6eSApple OSS Distributions
317*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_null_ipv6, "TCP send implied connect with the IPv6 null address", T_META_TAG_VM_PREFERRED)
318*4d495c6eSApple OSS Distributions {
319*4d495c6eSApple OSS Distributions int s = -1;
320*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
321*4d495c6eSApple OSS Distributions
322*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
323*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "::", &sin6.sin6_addr), 1, NULL);
324*4d495c6eSApple OSS Distributions
325*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
326*4d495c6eSApple OSS Distributions
327*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, 0), NULL);
328*4d495c6eSApple OSS Distributions
329*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
330*4d495c6eSApple OSS Distributions }
331*4d495c6eSApple OSS Distributions
332*4d495c6eSApple OSS Distributions // panics without rdar://124092232
333*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_loopback_via_ipv6_rdar_124092232, "TCP send implied v6 connect with IPv4 loopback", T_META_TAG_VM_PREFERRED)
334*4d495c6eSApple OSS Distributions {
335*4d495c6eSApple OSS Distributions int s = -1;
336*4d495c6eSApple OSS Distributions struct sockaddr_in sin = {0};
337*4d495c6eSApple OSS Distributions
338*4d495c6eSApple OSS Distributions init_sin_address(&sin);
339*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET, "127.0.0.1", &sin.sin_addr), 1, NULL);
340*4d495c6eSApple OSS Distributions
341*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
342*4d495c6eSApple OSS Distributions
343*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin, EAFNOSUPPORT), NULL);
344*4d495c6eSApple OSS Distributions
345*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
346*4d495c6eSApple OSS Distributions }
347*4d495c6eSApple OSS Distributions
348*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_multicast_mapped_ipv6, "TCP send implied connect with IPv4 multicast mapped IPv6 address", T_META_TAG_VM_PREFERRED)
349*4d495c6eSApple OSS Distributions {
350*4d495c6eSApple OSS Distributions int s = -1;
351*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
352*4d495c6eSApple OSS Distributions
353*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
354*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:224.0.0.1", &sin6.sin6_addr), 1, NULL);
355*4d495c6eSApple OSS Distributions
356*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
357*4d495c6eSApple OSS Distributions
358*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
359*4d495c6eSApple OSS Distributions
360*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
361*4d495c6eSApple OSS Distributions }
362*4d495c6eSApple OSS Distributions
363*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_broadcast_mapped_ipv6, "TCP send implied connect with IPv4 broadcast mapped IPv6 address", T_META_TAG_VM_PREFERRED)
364*4d495c6eSApple OSS Distributions {
365*4d495c6eSApple OSS Distributions int s = -1;
366*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
367*4d495c6eSApple OSS Distributions
368*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
369*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:255.255.255.255", &sin6.sin6_addr), 1, NULL);
370*4d495c6eSApple OSS Distributions
371*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
372*4d495c6eSApple OSS Distributions
373*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
374*4d495c6eSApple OSS Distributions
375*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
376*4d495c6eSApple OSS Distributions }
377*4d495c6eSApple OSS Distributions
378*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_null_mapped_ipv6, "TCP send implied connect with IPv4 null mapped IPv6 address", T_META_TAG_VM_PREFERRED)
379*4d495c6eSApple OSS Distributions {
380*4d495c6eSApple OSS Distributions int s = -1;
381*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
382*4d495c6eSApple OSS Distributions
383*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
384*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "::ffff:0.0.0.0", &sin6.sin6_addr), 1, NULL);
385*4d495c6eSApple OSS Distributions
386*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
387*4d495c6eSApple OSS Distributions
388*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, 0), NULL);
389*4d495c6eSApple OSS Distributions
390*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
391*4d495c6eSApple OSS Distributions }
392*4d495c6eSApple OSS Distributions
393*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_multicast_compatible_ipv6, "TCP send implied connect with IPv4 multicast compatible IPv6 address", T_META_TAG_VM_PREFERRED)
394*4d495c6eSApple OSS Distributions {
395*4d495c6eSApple OSS Distributions int s = -1;
396*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
397*4d495c6eSApple OSS Distributions
398*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
399*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "::224.0.0.1", &sin6.sin6_addr), 1, NULL);
400*4d495c6eSApple OSS Distributions
401*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
402*4d495c6eSApple OSS Distributions
403*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
404*4d495c6eSApple OSS Distributions
405*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
406*4d495c6eSApple OSS Distributions }
407*4d495c6eSApple OSS Distributions
408*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_broadcast_compatible_ipv6, "TCP send implied connect with IPv4 broadcast compatible IPv6 address", T_META_TAG_VM_PREFERRED)
409*4d495c6eSApple OSS Distributions {
410*4d495c6eSApple OSS Distributions int s = -1;
411*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
412*4d495c6eSApple OSS Distributions
413*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
414*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "::255.255.255.255", &sin6.sin6_addr), 1, NULL);
415*4d495c6eSApple OSS Distributions
416*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
417*4d495c6eSApple OSS Distributions
418*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, EAFNOSUPPORT), NULL);
419*4d495c6eSApple OSS Distributions
420*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
421*4d495c6eSApple OSS Distributions }
422*4d495c6eSApple OSS Distributions
423*4d495c6eSApple OSS Distributions T_DECL(tcp_send_implied_connect_ipv4_null_compatible_ipv6, "TCP send implied connect with IPv4 null compatible IPv6 address", T_META_TAG_VM_PREFERRED)
424*4d495c6eSApple OSS Distributions {
425*4d495c6eSApple OSS Distributions int s = -1;
426*4d495c6eSApple OSS Distributions struct sockaddr_in6 sin6 = {};
427*4d495c6eSApple OSS Distributions
428*4d495c6eSApple OSS Distributions init_sin6_address(&sin6);
429*4d495c6eSApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "::0.0.0.0", &sin6.sin6_addr), 1, NULL);
430*4d495c6eSApple OSS Distributions
431*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP), NULL);
432*4d495c6eSApple OSS Distributions
433*4d495c6eSApple OSS Distributions T_EXPECT_NULL(tcp_send_implied_connect_v6(s, &sin6, 0), NULL);
434*4d495c6eSApple OSS Distributions
435*4d495c6eSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(close(s), NULL);
436*4d495c6eSApple OSS Distributions }
437