1*a1e26a70SApple OSS Distributions /*
2*a1e26a70SApple OSS Distributions * Copyright (c) 2023-2024 Apple Inc. All rights reserved.
3*a1e26a70SApple OSS Distributions *
4*a1e26a70SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*a1e26a70SApple OSS Distributions *
6*a1e26a70SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code
7*a1e26a70SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License
8*a1e26a70SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in
9*a1e26a70SApple OSS Distributions * compliance with the License. The rights granted to you under the License
10*a1e26a70SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of,
11*a1e26a70SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to
12*a1e26a70SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any
13*a1e26a70SApple OSS Distributions * terms of an Apple operating system software license agreement.
14*a1e26a70SApple OSS Distributions *
15*a1e26a70SApple OSS Distributions * Please obtain a copy of the License at
16*a1e26a70SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*a1e26a70SApple OSS Distributions *
18*a1e26a70SApple OSS Distributions * The Original Code and all software distributed under the License are
19*a1e26a70SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*a1e26a70SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*a1e26a70SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*a1e26a70SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*a1e26a70SApple OSS Distributions * Please see the License for the specific language governing rights and
24*a1e26a70SApple OSS Distributions * limitations under the License.
25*a1e26a70SApple OSS Distributions *
26*a1e26a70SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*a1e26a70SApple OSS Distributions */
28*a1e26a70SApple OSS Distributions
29*a1e26a70SApple OSS Distributions #include <darwintest.h>
30*a1e26a70SApple OSS Distributions
31*a1e26a70SApple OSS Distributions #include <sys/ioctl.h>
32*a1e26a70SApple OSS Distributions
33*a1e26a70SApple OSS Distributions #include <stdlib.h>
34*a1e26a70SApple OSS Distributions #include <string.h>
35*a1e26a70SApple OSS Distributions #include <strings.h>
36*a1e26a70SApple OSS Distributions
37*a1e26a70SApple OSS Distributions #include "net_test_lib.h"
38*a1e26a70SApple OSS Distributions
39*a1e26a70SApple OSS Distributions T_GLOBAL_META(
40*a1e26a70SApple OSS Distributions T_META_NAMESPACE("xnu.net"),
41*a1e26a70SApple OSS Distributions T_META_ASROOT(true),
42*a1e26a70SApple OSS Distributions T_META_RADAR_COMPONENT_NAME("xnu"),
43*a1e26a70SApple OSS Distributions T_META_RADAR_COMPONENT_VERSION("networking"),
44*a1e26a70SApple OSS Distributions T_META_CHECK_LEAKS(false));
45*a1e26a70SApple OSS Distributions
46*a1e26a70SApple OSS Distributions static char ifname1[IF_NAMESIZE];
47*a1e26a70SApple OSS Distributions
48*a1e26a70SApple OSS Distributions /**
49*a1e26a70SApple OSS Distributions ** stolen from bootp/bootplib/util.c
50*a1e26a70SApple OSS Distributions **
51*a1e26a70SApple OSS Distributions **/
52*a1e26a70SApple OSS Distributions
53*a1e26a70SApple OSS Distributions #define ROUNDUP(a) \
54*a1e26a70SApple OSS Distributions ((a) > 0 ? (1 + (((a) - 1) | (sizeof(u_int32_t) - 1))) : sizeof(u_int32_t))
55*a1e26a70SApple OSS Distributions
56*a1e26a70SApple OSS Distributions static int
rt_xaddrs(char * cp,const char * cplim,struct rt_addrinfo * rtinfo)57*a1e26a70SApple OSS Distributions rt_xaddrs(char * cp, const char * cplim, struct rt_addrinfo * rtinfo)
58*a1e26a70SApple OSS Distributions {
59*a1e26a70SApple OSS Distributions int i;
60*a1e26a70SApple OSS Distributions struct sockaddr * sa;
61*a1e26a70SApple OSS Distributions
62*a1e26a70SApple OSS Distributions bzero(rtinfo->rti_info, sizeof(rtinfo->rti_info));
63*a1e26a70SApple OSS Distributions for (i = 0; (i < RTAX_MAX) && (cp < cplim); i++) {
64*a1e26a70SApple OSS Distributions if ((rtinfo->rti_addrs & (1 << i)) == 0) {
65*a1e26a70SApple OSS Distributions continue;
66*a1e26a70SApple OSS Distributions }
67*a1e26a70SApple OSS Distributions sa = (struct sockaddr *)cp;
68*a1e26a70SApple OSS Distributions if ((cp + sa->sa_len) > cplim) {
69*a1e26a70SApple OSS Distributions return EINVAL;
70*a1e26a70SApple OSS Distributions }
71*a1e26a70SApple OSS Distributions rtinfo->rti_info[i] = sa;
72*a1e26a70SApple OSS Distributions cp += ROUNDUP(sa->sa_len);
73*a1e26a70SApple OSS Distributions }
74*a1e26a70SApple OSS Distributions return 0;
75*a1e26a70SApple OSS Distributions }
76*a1e26a70SApple OSS Distributions
77*a1e26a70SApple OSS Distributions /**
78*a1e26a70SApple OSS Distributions ** stolen from bootp/IPConfiguration.bproj/iputil.c
79*a1e26a70SApple OSS Distributions **
80*a1e26a70SApple OSS Distributions ** inet6_addrlist_*
81*a1e26a70SApple OSS Distributions **/
82*a1e26a70SApple OSS Distributions
83*a1e26a70SApple OSS Distributions #define s6_addr16 __u6_addr.__u6_addr16
84*a1e26a70SApple OSS Distributions
85*a1e26a70SApple OSS Distributions static char *
copy_if_info(unsigned int if_index,int af,int * ret_len_p)86*a1e26a70SApple OSS Distributions copy_if_info(unsigned int if_index, int af, int *ret_len_p)
87*a1e26a70SApple OSS Distributions {
88*a1e26a70SApple OSS Distributions char * buf = NULL;
89*a1e26a70SApple OSS Distributions size_t buf_len = 0;
90*a1e26a70SApple OSS Distributions int mib[6];
91*a1e26a70SApple OSS Distributions
92*a1e26a70SApple OSS Distributions mib[0] = CTL_NET;
93*a1e26a70SApple OSS Distributions mib[1] = PF_ROUTE;
94*a1e26a70SApple OSS Distributions mib[2] = 0;
95*a1e26a70SApple OSS Distributions mib[3] = af;
96*a1e26a70SApple OSS Distributions mib[4] = NET_RT_IFLIST;
97*a1e26a70SApple OSS Distributions mib[5] = (int)if_index;
98*a1e26a70SApple OSS Distributions
99*a1e26a70SApple OSS Distributions *ret_len_p = 0;
100*a1e26a70SApple OSS Distributions if (sysctl(mib, 6, NULL, &buf_len, NULL, 0) < 0) {
101*a1e26a70SApple OSS Distributions fprintf(stderr, "sysctl() size failed: %s", strerror(errno));
102*a1e26a70SApple OSS Distributions goto failed;
103*a1e26a70SApple OSS Distributions }
104*a1e26a70SApple OSS Distributions buf_len *= 2; /* just in case something changes */
105*a1e26a70SApple OSS Distributions buf = malloc(buf_len);
106*a1e26a70SApple OSS Distributions if (sysctl(mib, 6, buf, &buf_len, NULL, 0) < 0) {
107*a1e26a70SApple OSS Distributions free(buf);
108*a1e26a70SApple OSS Distributions buf = NULL;
109*a1e26a70SApple OSS Distributions fprintf(stderr, "sysctl() failed: %s", strerror(errno));
110*a1e26a70SApple OSS Distributions goto failed;
111*a1e26a70SApple OSS Distributions }
112*a1e26a70SApple OSS Distributions *ret_len_p = (int)buf_len;
113*a1e26a70SApple OSS Distributions
114*a1e26a70SApple OSS Distributions failed:
115*a1e26a70SApple OSS Distributions return buf;
116*a1e26a70SApple OSS Distributions }
117*a1e26a70SApple OSS Distributions
118*a1e26a70SApple OSS Distributions static bool
inet6_get_linklocal_address(unsigned int if_index,struct in6_addr * ret_addr)119*a1e26a70SApple OSS Distributions inet6_get_linklocal_address(unsigned int if_index, struct in6_addr *ret_addr)
120*a1e26a70SApple OSS Distributions {
121*a1e26a70SApple OSS Distributions char * buf = NULL;
122*a1e26a70SApple OSS Distributions char * buf_end;
123*a1e26a70SApple OSS Distributions int buf_len;
124*a1e26a70SApple OSS Distributions bool found = FALSE;
125*a1e26a70SApple OSS Distributions char *scan;
126*a1e26a70SApple OSS Distributions struct rt_msghdr *rtm;
127*a1e26a70SApple OSS Distributions
128*a1e26a70SApple OSS Distributions bzero(ret_addr, sizeof(*ret_addr));
129*a1e26a70SApple OSS Distributions buf = copy_if_info(if_index, AF_INET6, &buf_len);
130*a1e26a70SApple OSS Distributions if (buf == NULL) {
131*a1e26a70SApple OSS Distributions goto done;
132*a1e26a70SApple OSS Distributions }
133*a1e26a70SApple OSS Distributions buf_end = buf + buf_len;
134*a1e26a70SApple OSS Distributions for (scan = buf; scan < buf_end; scan += rtm->rtm_msglen) {
135*a1e26a70SApple OSS Distributions struct ifa_msghdr * ifam;
136*a1e26a70SApple OSS Distributions struct rt_addrinfo info;
137*a1e26a70SApple OSS Distributions
138*a1e26a70SApple OSS Distributions /* ALIGN: buf aligned (from calling copy_if_info), scan aligned,
139*a1e26a70SApple OSS Distributions * cast ok. */
140*a1e26a70SApple OSS Distributions rtm = (struct rt_msghdr *)(void *)scan;
141*a1e26a70SApple OSS Distributions if (rtm->rtm_version != RTM_VERSION) {
142*a1e26a70SApple OSS Distributions continue;
143*a1e26a70SApple OSS Distributions }
144*a1e26a70SApple OSS Distributions if (rtm->rtm_type == RTM_NEWADDR) {
145*a1e26a70SApple OSS Distributions errno_t error;
146*a1e26a70SApple OSS Distributions struct sockaddr_in6 *sin6_p;
147*a1e26a70SApple OSS Distributions
148*a1e26a70SApple OSS Distributions ifam = (struct ifa_msghdr *)rtm;
149*a1e26a70SApple OSS Distributions info.rti_addrs = ifam->ifam_addrs;
150*a1e26a70SApple OSS Distributions error = rt_xaddrs((char *)(ifam + 1),
151*a1e26a70SApple OSS Distributions ((char *)ifam) + ifam->ifam_msglen,
152*a1e26a70SApple OSS Distributions &info);
153*a1e26a70SApple OSS Distributions if (error) {
154*a1e26a70SApple OSS Distributions fprintf(stderr, "couldn't extract rt_addrinfo %s (%d)\n",
155*a1e26a70SApple OSS Distributions strerror(error), error);
156*a1e26a70SApple OSS Distributions goto done;
157*a1e26a70SApple OSS Distributions }
158*a1e26a70SApple OSS Distributions /* ALIGN: info.rti_info aligned (sockaddr), cast ok. */
159*a1e26a70SApple OSS Distributions sin6_p = (struct sockaddr_in6 *)(void *)info.rti_info[RTAX_IFA];
160*a1e26a70SApple OSS Distributions if (sin6_p == NULL
161*a1e26a70SApple OSS Distributions || sin6_p->sin6_len < sizeof(struct sockaddr_in6)) {
162*a1e26a70SApple OSS Distributions continue;
163*a1e26a70SApple OSS Distributions }
164*a1e26a70SApple OSS Distributions if (IN6_IS_ADDR_LINKLOCAL(&sin6_p->sin6_addr)) {
165*a1e26a70SApple OSS Distributions *ret_addr = sin6_p->sin6_addr;
166*a1e26a70SApple OSS Distributions ret_addr->s6_addr16[1] = 0; /* mask scope id */
167*a1e26a70SApple OSS Distributions found = TRUE;
168*a1e26a70SApple OSS Distributions break;
169*a1e26a70SApple OSS Distributions }
170*a1e26a70SApple OSS Distributions }
171*a1e26a70SApple OSS Distributions }
172*a1e26a70SApple OSS Distributions
173*a1e26a70SApple OSS Distributions done:
174*a1e26a70SApple OSS Distributions if (buf != NULL) {
175*a1e26a70SApple OSS Distributions free(buf);
176*a1e26a70SApple OSS Distributions }
177*a1e26a70SApple OSS Distributions return found;
178*a1e26a70SApple OSS Distributions }
179*a1e26a70SApple OSS Distributions
180*a1e26a70SApple OSS Distributions static void
cleanup(void)181*a1e26a70SApple OSS Distributions cleanup(void)
182*a1e26a70SApple OSS Distributions {
183*a1e26a70SApple OSS Distributions if (ifname1[0] != '\0') {
184*a1e26a70SApple OSS Distributions T_LOG("ifnet_destroy %s", ifname1);
185*a1e26a70SApple OSS Distributions (void)ifnet_destroy(ifname1, false);
186*a1e26a70SApple OSS Distributions }
187*a1e26a70SApple OSS Distributions }
188*a1e26a70SApple OSS Distributions
189*a1e26a70SApple OSS Distributions static void
set_sockaddr_in6(struct sockaddr_in6 * sin6_p,const struct in6_addr * addr)190*a1e26a70SApple OSS Distributions set_sockaddr_in6(struct sockaddr_in6 *sin6_p, const struct in6_addr *addr)
191*a1e26a70SApple OSS Distributions {
192*a1e26a70SApple OSS Distributions sin6_p->sin6_family = AF_INET6;
193*a1e26a70SApple OSS Distributions sin6_p->sin6_len = sizeof(struct sockaddr_in6);
194*a1e26a70SApple OSS Distributions sin6_p->sin6_addr = *addr;
195*a1e26a70SApple OSS Distributions return;
196*a1e26a70SApple OSS Distributions }
197*a1e26a70SApple OSS Distributions
198*a1e26a70SApple OSS Distributions static int
inet6_difaddr(const char * name,const struct in6_addr * addr)199*a1e26a70SApple OSS Distributions inet6_difaddr(const char *name, const struct in6_addr *addr)
200*a1e26a70SApple OSS Distributions {
201*a1e26a70SApple OSS Distributions struct in6_ifreq ifr;
202*a1e26a70SApple OSS Distributions int s6 = inet6_dgram_socket_get();
203*a1e26a70SApple OSS Distributions
204*a1e26a70SApple OSS Distributions bzero(&ifr, sizeof(ifr));
205*a1e26a70SApple OSS Distributions strncpy(ifr.ifr_name, name, sizeof(ifr.ifr_name));
206*a1e26a70SApple OSS Distributions if (addr != NULL) {
207*a1e26a70SApple OSS Distributions set_sockaddr_in6(&ifr.ifr_ifru.ifru_addr, addr);
208*a1e26a70SApple OSS Distributions }
209*a1e26a70SApple OSS Distributions return ioctl(s6, SIOCDIFADDR_IN6, &ifr);
210*a1e26a70SApple OSS Distributions }
211*a1e26a70SApple OSS Distributions
212*a1e26a70SApple OSS Distributions static void
in6_len2mask(struct in6_addr * mask,int len)213*a1e26a70SApple OSS Distributions in6_len2mask(struct in6_addr *mask, int len)
214*a1e26a70SApple OSS Distributions {
215*a1e26a70SApple OSS Distributions int i;
216*a1e26a70SApple OSS Distributions
217*a1e26a70SApple OSS Distributions bzero(mask, sizeof(*mask));
218*a1e26a70SApple OSS Distributions for (i = 0; i < len / 8; i++) {
219*a1e26a70SApple OSS Distributions mask->s6_addr[i] = 0xff;
220*a1e26a70SApple OSS Distributions }
221*a1e26a70SApple OSS Distributions if (len % 8) {
222*a1e26a70SApple OSS Distributions mask->s6_addr[i] = (0xff00 >> (len % 8)) & 0xff;
223*a1e26a70SApple OSS Distributions }
224*a1e26a70SApple OSS Distributions }
225*a1e26a70SApple OSS Distributions
226*a1e26a70SApple OSS Distributions static int
inet6_aifaddr(const char * name,const struct in6_addr * addr,const struct in6_addr * dstaddr,int prefix_length,int flags,u_int32_t valid_lifetime,u_int32_t preferred_lifetime)227*a1e26a70SApple OSS Distributions inet6_aifaddr(const char *name, const struct in6_addr *addr,
228*a1e26a70SApple OSS Distributions const struct in6_addr *dstaddr, int prefix_length,
229*a1e26a70SApple OSS Distributions int flags,
230*a1e26a70SApple OSS Distributions u_int32_t valid_lifetime,
231*a1e26a70SApple OSS Distributions u_int32_t preferred_lifetime)
232*a1e26a70SApple OSS Distributions {
233*a1e26a70SApple OSS Distributions struct in6_aliasreq ifra_in6;
234*a1e26a70SApple OSS Distributions int s6 = inet6_dgram_socket_get();
235*a1e26a70SApple OSS Distributions
236*a1e26a70SApple OSS Distributions bzero(&ifra_in6, sizeof(ifra_in6));
237*a1e26a70SApple OSS Distributions strncpy(ifra_in6.ifra_name, name, sizeof(ifra_in6.ifra_name));
238*a1e26a70SApple OSS Distributions ifra_in6.ifra_lifetime.ia6t_vltime = valid_lifetime;
239*a1e26a70SApple OSS Distributions ifra_in6.ifra_lifetime.ia6t_pltime = preferred_lifetime;
240*a1e26a70SApple OSS Distributions ifra_in6.ifra_flags = flags;
241*a1e26a70SApple OSS Distributions if (addr != NULL) {
242*a1e26a70SApple OSS Distributions set_sockaddr_in6(&ifra_in6.ifra_addr, addr);
243*a1e26a70SApple OSS Distributions }
244*a1e26a70SApple OSS Distributions
245*a1e26a70SApple OSS Distributions if (dstaddr != NULL) {
246*a1e26a70SApple OSS Distributions set_sockaddr_in6(&ifra_in6.ifra_dstaddr, dstaddr);
247*a1e26a70SApple OSS Distributions }
248*a1e26a70SApple OSS Distributions
249*a1e26a70SApple OSS Distributions if (prefix_length != 0) {
250*a1e26a70SApple OSS Distributions struct in6_addr prefixmask;
251*a1e26a70SApple OSS Distributions
252*a1e26a70SApple OSS Distributions in6_len2mask(&prefixmask, prefix_length);
253*a1e26a70SApple OSS Distributions set_sockaddr_in6(&ifra_in6.ifra_prefixmask, &prefixmask);
254*a1e26a70SApple OSS Distributions }
255*a1e26a70SApple OSS Distributions
256*a1e26a70SApple OSS Distributions return ioctl(s6, SIOCAIFADDR_IN6, &ifra_in6);
257*a1e26a70SApple OSS Distributions }
258*a1e26a70SApple OSS Distributions
259*a1e26a70SApple OSS Distributions static void
create_fake_interface(void)260*a1e26a70SApple OSS Distributions create_fake_interface(void)
261*a1e26a70SApple OSS Distributions {
262*a1e26a70SApple OSS Distributions int error;
263*a1e26a70SApple OSS Distributions
264*a1e26a70SApple OSS Distributions strlcpy(ifname1, FETH_NAME, sizeof(ifname1));
265*a1e26a70SApple OSS Distributions error = ifnet_create_2(ifname1, sizeof(ifname1));
266*a1e26a70SApple OSS Distributions if (error != 0) {
267*a1e26a70SApple OSS Distributions ifname1[0] = '\0';
268*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(error, "ifnet_create_2");
269*a1e26a70SApple OSS Distributions }
270*a1e26a70SApple OSS Distributions T_LOG("created %s", ifname1);
271*a1e26a70SApple OSS Distributions }
272*a1e26a70SApple OSS Distributions
273*a1e26a70SApple OSS Distributions T_DECL(inet6_addr_mode_auto_to_manual, "inet6 address mode-switching (auto -> manual)")
274*a1e26a70SApple OSS Distributions {
275*a1e26a70SApple OSS Distributions struct in6_addr lladdr;
276*a1e26a70SApple OSS Distributions struct in6_addr newaddr;
277*a1e26a70SApple OSS Distributions unsigned int if_index;
278*a1e26a70SApple OSS Distributions
279*a1e26a70SApple OSS Distributions T_ATEND(cleanup);
280*a1e26a70SApple OSS Distributions
281*a1e26a70SApple OSS Distributions create_fake_interface();
282*a1e26a70SApple OSS Distributions ifnet_start_ipv6(ifname1);
283*a1e26a70SApple OSS Distributions
284*a1e26a70SApple OSS Distributions if_index = if_nametoindex(ifname1);
285*a1e26a70SApple OSS Distributions T_EXPECT_GT(if_index, 0, NULL);
286*a1e26a70SApple OSS Distributions T_ASSERT_EQ(inet6_get_linklocal_address(if_index, &lladdr), 1, NULL);
287*a1e26a70SApple OSS Distributions
288*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(inet6_aifaddr(ifname1, &lladdr, NULL, 64, 123, ND6_INFINITE_LIFETIME, ND6_INFINITE_LIFETIME), NULL);
289*a1e26a70SApple OSS Distributions
290*a1e26a70SApple OSS Distributions /* Create address as an autoconfed address */
291*a1e26a70SApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "2001:db8::3", &newaddr), 1, NULL);
292*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(inet6_aifaddr(ifname1, &newaddr, NULL, 64, (IN6_IFF_AUTOCONF | IN6_IFF_TEMPORARY), ND6_INFINITE_LIFETIME, ND6_INFINITE_LIFETIME), NULL);
293*a1e26a70SApple OSS Distributions
294*a1e26a70SApple OSS Distributions /* Now mark it as manual */
295*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(inet6_aifaddr(ifname1, &newaddr, NULL, 64, 0, ND6_INFINITE_LIFETIME, ND6_INFINITE_LIFETIME), NULL);
296*a1e26a70SApple OSS Distributions
297*a1e26a70SApple OSS Distributions /* Deleting address should NOT result in panic */
298*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(inet6_difaddr(ifname1, &newaddr), NULL);
299*a1e26a70SApple OSS Distributions }
300*a1e26a70SApple OSS Distributions
301*a1e26a70SApple OSS Distributions T_DECL(inet6_addr_mode_manual_to_auto, "inet6 address mode-switching (manual -> auto)")
302*a1e26a70SApple OSS Distributions {
303*a1e26a70SApple OSS Distributions struct in6_addr lladdr;
304*a1e26a70SApple OSS Distributions struct in6_addr newaddr;
305*a1e26a70SApple OSS Distributions unsigned int if_index;
306*a1e26a70SApple OSS Distributions
307*a1e26a70SApple OSS Distributions T_ATEND(cleanup);
308*a1e26a70SApple OSS Distributions create_fake_interface();
309*a1e26a70SApple OSS Distributions
310*a1e26a70SApple OSS Distributions T_LOG("created %s", ifname1);
311*a1e26a70SApple OSS Distributions
312*a1e26a70SApple OSS Distributions ifnet_start_ipv6(ifname1);
313*a1e26a70SApple OSS Distributions
314*a1e26a70SApple OSS Distributions if_index = if_nametoindex(ifname1);
315*a1e26a70SApple OSS Distributions T_EXPECT_GT(if_index, 0, NULL);
316*a1e26a70SApple OSS Distributions T_ASSERT_EQ(inet6_get_linklocal_address(if_index, &lladdr), 1, NULL);
317*a1e26a70SApple OSS Distributions
318*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(inet6_aifaddr(ifname1, &lladdr, NULL, 64, 123, ND6_INFINITE_LIFETIME, ND6_INFINITE_LIFETIME), NULL);
319*a1e26a70SApple OSS Distributions
320*a1e26a70SApple OSS Distributions /* Create address as a manual address */
321*a1e26a70SApple OSS Distributions T_ASSERT_EQ(inet_pton(AF_INET6, "2001:db8::1", &newaddr), 1, NULL);
322*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(inet6_aifaddr(ifname1, &newaddr, NULL, 64, 0, ND6_INFINITE_LIFETIME, ND6_INFINITE_LIFETIME), NULL);
323*a1e26a70SApple OSS Distributions
324*a1e26a70SApple OSS Distributions /* Now make it autoconfed */
325*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(inet6_aifaddr(ifname1, &newaddr, NULL, 64, (IN6_IFF_AUTOCONF | IN6_IFF_TEMPORARY), ND6_INFINITE_LIFETIME, ND6_INFINITE_LIFETIME), NULL);
326*a1e26a70SApple OSS Distributions
327*a1e26a70SApple OSS Distributions /* Deleting address should NOT result in panic */
328*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(inet6_difaddr(ifname1, &newaddr), NULL);
329*a1e26a70SApple OSS Distributions }
330