1*4d495c6eSApple OSS Distributions #include <darwintest.h> 2*4d495c6eSApple OSS Distributions #include "../bsd/sys/proc_info.h" 3*4d495c6eSApple OSS Distributions #include "../libsyscall/wrappers/libproc/libproc.h" 4*4d495c6eSApple OSS Distributions #include <stdio.h> 5*4d495c6eSApple OSS Distributions #include <unistd.h> 6*4d495c6eSApple OSS Distributions #include <TargetConditionals.h> 7*4d495c6eSApple OSS Distributions 8*4d495c6eSApple OSS Distributions T_GLOBAL_META(T_META_RUN_CONCURRENTLY(true)); 9*4d495c6eSApple OSS Distributions 10*4d495c6eSApple OSS Distributions T_DECL(proc_udata_info, "Get and set a proc udata token", T_META_TAG_VM_PREFERRED){ 11*4d495c6eSApple OSS Distributions uint64_t token = mach_absolute_time(); 12*4d495c6eSApple OSS Distributions proc_info_udata_t udata; 13*4d495c6eSApple OSS Distributions int ret; 14*4d495c6eSApple OSS Distributions 15*4d495c6eSApple OSS Distributions udata = token; 16*4d495c6eSApple OSS Distributions ret = proc_udata_info(getpid(), PROC_UDATA_INFO_SET, &udata, sizeof(udata)); 17*4d495c6eSApple OSS Distributions 18*4d495c6eSApple OSS Distributions #if !TARGET_OS_OSX 19*4d495c6eSApple OSS Distributions T_WITH_ERRNO; 20*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(ret, -1, "proc_udata_info PROC_UDATA_INFO_SET returns error on non-supported platforms"); 21*4d495c6eSApple OSS Distributions T_SKIP("Remaining tests are only supported on platforms with CONFIG_PROC_UDATA_STORAGE configured"); 22*4d495c6eSApple OSS Distributions #endif 23*4d495c6eSApple OSS Distributions 24*4d495c6eSApple OSS Distributions T_WITH_ERRNO; 25*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(ret, 0, "proc_udata_info PROC_UDATA_INFO_SET"); 26*4d495c6eSApple OSS Distributions 27*4d495c6eSApple OSS Distributions T_LOG("udata set to %#llx", udata); 28*4d495c6eSApple OSS Distributions 29*4d495c6eSApple OSS Distributions bzero(&udata, sizeof(udata)); 30*4d495c6eSApple OSS Distributions ret = proc_udata_info(getpid(), PROC_UDATA_INFO_GET, &udata, sizeof(udata)); 31*4d495c6eSApple OSS Distributions T_WITH_ERRNO; 32*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(ret, 0, "proc_udata_info PROC_UDATA_INFO_GET"); 33*4d495c6eSApple OSS Distributions 34*4d495c6eSApple OSS Distributions T_ASSERT_EQ_ULLONG(token, udata, "proc_udata_info(): retrieved value matches token"); 35*4d495c6eSApple OSS Distributions 36*4d495c6eSApple OSS Distributions ret = proc_udata_info(getpid(), PROC_UDATA_INFO_SET, &udata, sizeof(uint32_t)); 37*4d495c6eSApple OSS Distributions T_WITH_ERRNO; 38*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(ret, -1, "proc_udata_info PROC_UDATA_INFO_SET with invalid size returned -1"); 39*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(errno, EINVAL, "proc_udata_info PROC_UDATA_INFO_SET with invalid size returned EINVAL"); 40*4d495c6eSApple OSS Distributions 41*4d495c6eSApple OSS Distributions ret = proc_udata_info(getppid(), PROC_UDATA_INFO_GET, &udata, sizeof(udata)); 42*4d495c6eSApple OSS Distributions T_WITH_ERRNO; 43*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(ret, -1, "proc_udata_info PROC_UDATA_INFO_GET returned -1 on attempt against non-self pid"); 44*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(errno, EACCES, "proc_udata_info PROC_UDATA_INFO_GET set errno to EACCES on attempt against non-self pid"); 45*4d495c6eSApple OSS Distributions 46*4d495c6eSApple OSS Distributions ret = proc_udata_info(getppid(), PROC_UDATA_INFO_SET, &udata, sizeof(udata)); 47*4d495c6eSApple OSS Distributions T_WITH_ERRNO; 48*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(ret, -1, "proc_udata_info PROC_UDATA_INFO_SET returned -1 on attempt against non-self pid"); 49*4d495c6eSApple OSS Distributions T_ASSERT_EQ_INT(errno, EACCES, "proc_udata_info PROC_UDATA_INFO_SET set errno to EACCES on attempt against non-self pid"); 50*4d495c6eSApple OSS Distributions } 51