xref: /xnu-12377.41.6/tests/net_tun_pr_35136664.c (revision bbb1b6f9e71b8cdde6e5cd6f4841f207dee3d828)
1*bbb1b6f9SApple OSS Distributions #include <sys/ioctl.h>
2*bbb1b6f9SApple OSS Distributions #include <sys/socket.h>
3*bbb1b6f9SApple OSS Distributions #include <sys/kern_control.h>
4*bbb1b6f9SApple OSS Distributions #include <sys/sys_domain.h>
5*bbb1b6f9SApple OSS Distributions 
6*bbb1b6f9SApple OSS Distributions #include <net/if_utun.h>
7*bbb1b6f9SApple OSS Distributions #include <net/if_ipsec.h>
8*bbb1b6f9SApple OSS Distributions 
9*bbb1b6f9SApple OSS Distributions #include <darwintest.h>
10*bbb1b6f9SApple OSS Distributions #include <darwintest_utils.h>
11*bbb1b6f9SApple OSS Distributions 
12*bbb1b6f9SApple OSS Distributions T_GLOBAL_META(T_META_NAMESPACE("xnu.net"),
13*bbb1b6f9SApple OSS Distributions     T_META_RUN_CONCURRENTLY(true),
14*bbb1b6f9SApple OSS Distributions     T_META_ASROOT(true));
15*bbb1b6f9SApple OSS Distributions 
16*bbb1b6f9SApple OSS Distributions T_DECL(PR_35136664_utun,
17*bbb1b6f9SApple OSS Distributions     "This bind a utun and close it without connecting", T_META_TAG_VM_PREFERRED)
18*bbb1b6f9SApple OSS Distributions {
19*bbb1b6f9SApple OSS Distributions 	int tunsock;
20*bbb1b6f9SApple OSS Distributions 	struct ctl_info kernctl_info;
21*bbb1b6f9SApple OSS Distributions 	struct sockaddr_ctl kernctl_addr;
22*bbb1b6f9SApple OSS Distributions 
23*bbb1b6f9SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(tunsock = socket(PF_SYSTEM, SOCK_DGRAM, SYSPROTO_CONTROL), NULL);
24*bbb1b6f9SApple OSS Distributions 
25*bbb1b6f9SApple OSS Distributions 	memset(&kernctl_info, 0, sizeof(kernctl_info));
26*bbb1b6f9SApple OSS Distributions 	strlcpy(kernctl_info.ctl_name, UTUN_CONTROL_NAME, sizeof(kernctl_info.ctl_name));
27*bbb1b6f9SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(ioctl(tunsock, CTLIOCGINFO, &kernctl_info), NULL);
28*bbb1b6f9SApple OSS Distributions 
29*bbb1b6f9SApple OSS Distributions 	memset(&kernctl_addr, 0, sizeof(kernctl_addr));
30*bbb1b6f9SApple OSS Distributions 	kernctl_addr.sc_len = sizeof(kernctl_addr);
31*bbb1b6f9SApple OSS Distributions 	kernctl_addr.sc_family = AF_SYSTEM;
32*bbb1b6f9SApple OSS Distributions 	kernctl_addr.ss_sysaddr = AF_SYS_CONTROL;
33*bbb1b6f9SApple OSS Distributions 	kernctl_addr.sc_id = kernctl_info.ctl_id;
34*bbb1b6f9SApple OSS Distributions 	kernctl_addr.sc_unit = 0;
35*bbb1b6f9SApple OSS Distributions 
36*bbb1b6f9SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(tunsock, (struct sockaddr *)&kernctl_addr, sizeof(kernctl_addr)), NULL);
37*bbb1b6f9SApple OSS Distributions 
38*bbb1b6f9SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(tunsock), NULL);
39*bbb1b6f9SApple OSS Distributions }
40*bbb1b6f9SApple OSS Distributions 
41*bbb1b6f9SApple OSS Distributions T_DECL(PR_35136664_ipsec,
42*bbb1b6f9SApple OSS Distributions     "This bind a ipsec and close it without connecting", T_META_TAG_VM_PREFERRED)
43*bbb1b6f9SApple OSS Distributions {
44*bbb1b6f9SApple OSS Distributions 	int tunsock;
45*bbb1b6f9SApple OSS Distributions 	struct ctl_info kernctl_info;
46*bbb1b6f9SApple OSS Distributions 	struct sockaddr_ctl kernctl_addr;
47*bbb1b6f9SApple OSS Distributions 
48*bbb1b6f9SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(tunsock = socket(PF_SYSTEM, SOCK_DGRAM, SYSPROTO_CONTROL), NULL);
49*bbb1b6f9SApple OSS Distributions 
50*bbb1b6f9SApple OSS Distributions 	memset(&kernctl_info, 0, sizeof(kernctl_info));
51*bbb1b6f9SApple OSS Distributions 	strlcpy(kernctl_info.ctl_name, IPSEC_CONTROL_NAME, sizeof(kernctl_info.ctl_name));
52*bbb1b6f9SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(ioctl(tunsock, CTLIOCGINFO, &kernctl_info), NULL);
53*bbb1b6f9SApple OSS Distributions 
54*bbb1b6f9SApple OSS Distributions 	memset(&kernctl_addr, 0, sizeof(kernctl_addr));
55*bbb1b6f9SApple OSS Distributions 	kernctl_addr.sc_len = sizeof(kernctl_addr);
56*bbb1b6f9SApple OSS Distributions 	kernctl_addr.sc_family = AF_SYSTEM;
57*bbb1b6f9SApple OSS Distributions 	kernctl_addr.ss_sysaddr = AF_SYS_CONTROL;
58*bbb1b6f9SApple OSS Distributions 	kernctl_addr.sc_id = kernctl_info.ctl_id;
59*bbb1b6f9SApple OSS Distributions 	kernctl_addr.sc_unit = 0;
60*bbb1b6f9SApple OSS Distributions 
61*bbb1b6f9SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(bind(tunsock, (struct sockaddr *)&kernctl_addr, sizeof(kernctl_addr)), NULL);
62*bbb1b6f9SApple OSS Distributions 
63*bbb1b6f9SApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(close(tunsock), NULL);
64*bbb1b6f9SApple OSS Distributions }
65