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