1*043036a2SApple OSS Distributions /* 2*043036a2SApple OSS Distributions * Copyright (c) 2000-2021 Apple Inc. All rights reserved. 3*043036a2SApple OSS Distributions * 4*043036a2SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5*043036a2SApple OSS Distributions * 6*043036a2SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 7*043036a2SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 8*043036a2SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 9*043036a2SApple OSS Distributions * compliance with the License. The rights granted to you under the License 10*043036a2SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 11*043036a2SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 12*043036a2SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 13*043036a2SApple OSS Distributions * terms of an Apple operating system software license agreement. 14*043036a2SApple OSS Distributions * 15*043036a2SApple OSS Distributions * Please obtain a copy of the License at 16*043036a2SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 17*043036a2SApple OSS Distributions * 18*043036a2SApple OSS Distributions * The Original Code and all software distributed under the License are 19*043036a2SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20*043036a2SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21*043036a2SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22*043036a2SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23*043036a2SApple OSS Distributions * Please see the License for the specific language governing rights and 24*043036a2SApple OSS Distributions * limitations under the License. 25*043036a2SApple OSS Distributions * 26*043036a2SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27*043036a2SApple OSS Distributions */ 28*043036a2SApple OSS Distributions 29*043036a2SApple OSS Distributions #ifndef _SYS_RESOURCE_PRIVATE_H_ 30*043036a2SApple OSS Distributions #define _SYS_RESOURCE_PRIVATE_H_ 31*043036a2SApple OSS Distributions 32*043036a2SApple OSS Distributions #include <os/base.h> 33*043036a2SApple OSS Distributions #include <stdint.h> 34*043036a2SApple OSS Distributions #include <sys/cdefs.h> 35*043036a2SApple OSS Distributions 36*043036a2SApple OSS Distributions /* 37*043036a2SApple OSS Distributions * The kind of counters to copy into the destination buffer with 38*043036a2SApple OSS Distributions * `thread_selfcounts`. 39*043036a2SApple OSS Distributions */ 40*043036a2SApple OSS Distributions __enum_decl(thread_selfcounts_kind_t, uint32_t, { 41*043036a2SApple OSS Distributions /* 42*043036a2SApple OSS Distributions * Get the current thread's cycles and instructions -- may return ENOTSUP 43*043036a2SApple OSS Distributions * on certain hardware. 44*043036a2SApple OSS Distributions */ 45*043036a2SApple OSS Distributions THSC_CPI = 1, 46*043036a2SApple OSS Distributions /* 47*043036a2SApple OSS Distributions * Same as `THSC_CPI`, except fills in an array indexed by CPU perf-level, 48*043036a2SApple OSS Distributions * with `sysctl hw.nperflevels` entries. 49*043036a2SApple OSS Distributions */ 50*043036a2SApple OSS Distributions THSC_CPI_PER_PERF_LEVEL = 2, 51*043036a2SApple OSS Distributions /* 52*043036a2SApple OSS Distributions * Get the current thread's cycles, instructions, user time and system time. 53*043036a2SApple OSS Distributions * Instructions and cycles may be left 0 on certain hardware. System time 54*043036a2SApple OSS Distributions * may be accounted for by user time and left 0 on certain hardware. 55*043036a2SApple OSS Distributions */ 56*043036a2SApple OSS Distributions THSC_TIME_CPI = 3, 57*043036a2SApple OSS Distributions /* 58*043036a2SApple OSS Distributions * Same as `THSC_TIME_CPI`, except fills in an array indexed by CPU 59*043036a2SApple OSS Distributions * perf-level, with `sysctl hw.nperflevels` entries. 60*043036a2SApple OSS Distributions */ 61*043036a2SApple OSS Distributions THSC_TIME_CPI_PER_PERF_LEVEL = 4, 62*043036a2SApple OSS Distributions /* 63*043036a2SApple OSS Distributions * Get the current thread's cycles, instructions, times, and energy usage. 64*043036a2SApple OSS Distributions */ 65*043036a2SApple OSS Distributions THSC_TIME_ENERGY_CPI = 5, 66*043036a2SApple OSS Distributions /* 67*043036a2SApple OSS Distributions * Same as `THSC_TIME_ENERGY_CPI`, except fills in an array indexd by CPU 68*043036a2SApple OSS Distributions * perf-level, with `sysctl hw.nperflevels` entries. 69*043036a2SApple OSS Distributions */ 70*043036a2SApple OSS Distributions THSC_TIME_ENERGY_CPI_PER_PERF_LEVEL = 6, 71*043036a2SApple OSS Distributions }); 72*043036a2SApple OSS Distributions 73*043036a2SApple OSS Distributions /* 74*043036a2SApple OSS Distributions * The data structure expected by `THSC_CPI*`. 75*043036a2SApple OSS Distributions */ 76*043036a2SApple OSS Distributions struct thsc_cpi { 77*043036a2SApple OSS Distributions uint64_t tcpi_instructions; 78*043036a2SApple OSS Distributions uint64_t tcpi_cycles; 79*043036a2SApple OSS Distributions }; 80*043036a2SApple OSS Distributions 81*043036a2SApple OSS Distributions /* 82*043036a2SApple OSS Distributions * The data structure expected by `THSC_TIME_CPI*`. 83*043036a2SApple OSS Distributions */ 84*043036a2SApple OSS Distributions struct thsc_time_cpi { 85*043036a2SApple OSS Distributions uint64_t ttci_instructions; 86*043036a2SApple OSS Distributions uint64_t ttci_cycles; 87*043036a2SApple OSS Distributions uint64_t ttci_user_time_mach; 88*043036a2SApple OSS Distributions uint64_t ttci_system_time_mach; 89*043036a2SApple OSS Distributions }; 90*043036a2SApple OSS Distributions 91*043036a2SApple OSS Distributions /* 92*043036a2SApple OSS Distributions * The data structure expected by `THSC_TIME_ENERGY_CPI*`. 93*043036a2SApple OSS Distributions */ 94*043036a2SApple OSS Distributions struct thsc_time_energy_cpi { 95*043036a2SApple OSS Distributions uint64_t ttec_instructions; 96*043036a2SApple OSS Distributions uint64_t ttec_cycles; 97*043036a2SApple OSS Distributions uint64_t ttec_user_time_mach; 98*043036a2SApple OSS Distributions uint64_t ttec_system_time_mach; 99*043036a2SApple OSS Distributions uint64_t ttec_energy_nj; 100*043036a2SApple OSS Distributions }; 101*043036a2SApple OSS Distributions 102*043036a2SApple OSS Distributions #ifndef KERNEL 103*043036a2SApple OSS Distributions 104*043036a2SApple OSS Distributions #include <stddef.h> 105*043036a2SApple OSS Distributions #include <Availability.h> 106*043036a2SApple OSS Distributions #include <AvailabilityInternalPrivate.h> 107*043036a2SApple OSS Distributions 108*043036a2SApple OSS Distributions __BEGIN_DECLS 109*043036a2SApple OSS Distributions 110*043036a2SApple OSS Distributions /* 111*043036a2SApple OSS Distributions * Get the current thread's counters according to a `kind` and store them into 112*043036a2SApple OSS Distributions * `dst`. 113*043036a2SApple OSS Distributions */ 114*043036a2SApple OSS Distributions __SPI_AVAILABLE(macos(12.4), ios(15.4), watchos(8.5), tvos(15.4)) 115*043036a2SApple OSS Distributions int thread_selfcounts(thread_selfcounts_kind_t kind, void *dst, size_t size); 116*043036a2SApple OSS Distributions 117*043036a2SApple OSS Distributions __END_DECLS 118*043036a2SApple OSS Distributions 119*043036a2SApple OSS Distributions #endif /* !defined(KERNEL) */ 120*043036a2SApple OSS Distributions 121*043036a2SApple OSS Distributions /* Additional private parameters to getpriority()/setpriority() */ 122*043036a2SApple OSS Distributions 123*043036a2SApple OSS Distributions #define PRIO_DARWIN_GPU 5 /* Second argument is a PID */ 124*043036a2SApple OSS Distributions 125*043036a2SApple OSS Distributions __enum_decl(darwin_gpu_role_t, uint8_t, { 126*043036a2SApple OSS Distributions /* GPU Role unmanaged, default value at task start */ 127*043036a2SApple OSS Distributions PRIO_DARWIN_GPU_UNKNOWN = 0x0, 128*043036a2SApple OSS Distributions /* existing allow state for compatibility */ 129*043036a2SApple OSS Distributions PRIO_DARWIN_GPU_ALLOW = 0x1, 130*043036a2SApple OSS Distributions /* GPU access is denied by Runningboard */ 131*043036a2SApple OSS Distributions PRIO_DARWIN_GPU_DENY = 0x2, 132*043036a2SApple OSS Distributions /* Allowed to use GPU at Background priority, not visible to user, prioritizes running most-efficiently */ 133*043036a2SApple OSS Distributions PRIO_DARWIN_GPU_BACKGROUND = 0x3, 134*043036a2SApple OSS Distributions /* GPU used for non-visible-UI long-running progress-bar workloads, balances between sustainable thermals and perf */ 135*043036a2SApple OSS Distributions PRIO_DARWIN_GPU_UTILITY = 0x4, 136*043036a2SApple OSS Distributions /* Renders visible UI, known to be a non-focal app */ 137*043036a2SApple OSS Distributions PRIO_DARWIN_GPU_UI_NON_FOCAL = 0x5, 138*043036a2SApple OSS Distributions /* Renders visible UI, unknown focality */ 139*043036a2SApple OSS Distributions PRIO_DARWIN_GPU_UI = 0x6, 140*043036a2SApple OSS Distributions /* Renders visible UI, is part of a focal app */ 141*043036a2SApple OSS Distributions PRIO_DARWIN_GPU_UI_FOCAL = 0x7, 142*043036a2SApple OSS Distributions }); 143*043036a2SApple OSS Distributions 144*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE 6 /* Second argument is a PID */ 145*043036a2SApple OSS Distributions 146*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE_DEFAULT 0x0 /* Reset to default state */ 147*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE_UI_FOCAL 0x1 /* On screen, focal UI */ 148*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE_UI 0x2 /* On screen UI, focal unknown */ 149*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE_NON_UI 0x3 /* Off screen, non-focal UI */ 150*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE_UI_NON_FOCAL 0x4 /* On screen, non-focal UI */ 151*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE_TAL_LAUNCH 0x5 /* Throttled-launch (for OS X TAL resume) */ 152*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE_DARWIN_BG 0x6 /* Throttled for running in the background */ 153*043036a2SApple OSS Distributions #define PRIO_DARWIN_ROLE_USER_INIT 0x7 /* Off-screen doing user-initiated work */ 154*043036a2SApple OSS Distributions 155*043036a2SApple OSS Distributions #define PRIO_DARWIN_GAME_MODE 7 /* Second argument is a PID */ 156*043036a2SApple OSS Distributions #define PRIO_DARWIN_CARPLAY_MODE 8 /* Second argument is a PID */ 157*043036a2SApple OSS Distributions #define PRIO_DARWIN_RUNAWAY_MITIGATION 9 /* Second argument is a PID */ 158*043036a2SApple OSS Distributions 159*043036a2SApple OSS Distributions #define PRIO_DARWIN_GAME_MODE_OFF 0x0 160*043036a2SApple OSS Distributions #define PRIO_DARWIN_GAME_MODE_ON 0x1 161*043036a2SApple OSS Distributions 162*043036a2SApple OSS Distributions #define PRIO_DARWIN_CARPLAY_MODE_OFF 0x0 163*043036a2SApple OSS Distributions #define PRIO_DARWIN_CARPLAY_MODE_ON 0x1 164*043036a2SApple OSS Distributions 165*043036a2SApple OSS Distributions #define PRIO_DARWIN_RUNAWAY_MITIGATION_OFF 0x0 166*043036a2SApple OSS Distributions #define PRIO_DARWIN_RUNAWAY_MITIGATION_ON 0x1 167*043036a2SApple OSS Distributions 168*043036a2SApple OSS Distributions /* 169*043036a2SApple OSS Distributions * Flags for I/O monitor control. 170*043036a2SApple OSS Distributions */ 171*043036a2SApple OSS Distributions #define IOMON_ENABLE 0x01 172*043036a2SApple OSS Distributions #define IOMON_DISABLE 0x02 173*043036a2SApple OSS Distributions 174*043036a2SApple OSS Distributions /* Private I/O type */ 175*043036a2SApple OSS Distributions #define IOPOL_TYPE_VFS_HFS_CASE_SENSITIVITY 1 176*043036a2SApple OSS Distributions #define IOPOL_TYPE_VFS_ALTLINK 11 177*043036a2SApple OSS Distributions #define IOPOL_TYPE_VFS_NOCACHE_WRITE_FS_BLKSIZE 12 178*043036a2SApple OSS Distributions #define IOPOL_TYPE_VFS_SUPPORT_LONG_PATHS 13 179*043036a2SApple OSS Distributions 180*043036a2SApple OSS Distributions #define IOPOL_VFS_HFS_CASE_SENSITIVITY_DEFAULT 0 181*043036a2SApple OSS Distributions #define IOPOL_VFS_HFS_CASE_SENSITIVITY_FORCE_CASE_SENSITIVE 1 182*043036a2SApple OSS Distributions 183*043036a2SApple OSS Distributions #define IOPOL_VFS_ALTLINK_DISABLED 0 184*043036a2SApple OSS Distributions #define IOPOL_VFS_ALTLINK_ENABLED 1 185*043036a2SApple OSS Distributions 186*043036a2SApple OSS Distributions #define IOPOL_VFS_SUPPORT_LONG_PATHS_DEFAULT 0 187*043036a2SApple OSS Distributions #define IOPOL_VFS_SUPPORT_LONG_PATHS_ON 1 188*043036a2SApple OSS Distributions 189*043036a2SApple OSS Distributions /* 190*043036a2SApple OSS Distributions * Structures for use in communicating via iopolicysys() between Libc and the 191*043036a2SApple OSS Distributions * kernel. Not to be used by user programs directly. 192*043036a2SApple OSS Distributions */ 193*043036a2SApple OSS Distributions 194*043036a2SApple OSS Distributions /* 195*043036a2SApple OSS Distributions * the command to iopolicysys() 196*043036a2SApple OSS Distributions */ 197*043036a2SApple OSS Distributions #define IOPOL_CMD_GET 0x00000001 /* Get I/O policy */ 198*043036a2SApple OSS Distributions #define IOPOL_CMD_SET 0x00000002 /* Set I/O policy */ 199*043036a2SApple OSS Distributions 200*043036a2SApple OSS Distributions /* 201*043036a2SApple OSS Distributions * Second parameter to iopolicysys() 202*043036a2SApple OSS Distributions */ 203*043036a2SApple OSS Distributions struct _iopol_param_t { 204*043036a2SApple OSS Distributions int iop_scope; /* current process or a thread */ 205*043036a2SApple OSS Distributions int iop_iotype; 206*043036a2SApple OSS Distributions int iop_policy; 207*043036a2SApple OSS Distributions }; 208*043036a2SApple OSS Distributions 209*043036a2SApple OSS Distributions #endif /* !defined(_SYS_RESOURCE_PRIVATE_H_) */ 210