1*e7776783SApple OSS Distributions /* 2*e7776783SApple OSS Distributions * Copyright (c) 2008 Apple Inc. All rights reserved. 3*e7776783SApple OSS Distributions * 4*e7776783SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5*e7776783SApple OSS Distributions * 6*e7776783SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 7*e7776783SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 8*e7776783SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 9*e7776783SApple OSS Distributions * compliance with the License. The rights granted to you under the License 10*e7776783SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 11*e7776783SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 12*e7776783SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 13*e7776783SApple OSS Distributions * terms of an Apple operating system software license agreement. 14*e7776783SApple OSS Distributions * 15*e7776783SApple OSS Distributions * Please obtain a copy of the License at 16*e7776783SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 17*e7776783SApple OSS Distributions * 18*e7776783SApple OSS Distributions * The Original Code and all software distributed under the License are 19*e7776783SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20*e7776783SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21*e7776783SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22*e7776783SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23*e7776783SApple OSS Distributions * Please see the License for the specific language governing rights and 24*e7776783SApple OSS Distributions * limitations under the License. 25*e7776783SApple OSS Distributions * 26*e7776783SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27*e7776783SApple OSS Distributions */ 28*e7776783SApple OSS Distributions /* 29*e7776783SApple OSS Distributions * Timer queue support routines. 30*e7776783SApple OSS Distributions */ 31*e7776783SApple OSS Distributions 32*e7776783SApple OSS Distributions #ifndef _KERN_TIMER_QUEUE_H_ 33*e7776783SApple OSS Distributions #define _KERN_TIMER_QUEUE_H_ 34*e7776783SApple OSS Distributions 35*e7776783SApple OSS Distributions #include <mach/mach_types.h> 36*e7776783SApple OSS Distributions 37*e7776783SApple OSS Distributions #ifdef MACH_KERNEL_PRIVATE 38*e7776783SApple OSS Distributions 39*e7776783SApple OSS Distributions #include <kern/mpqueue.h> 40*e7776783SApple OSS Distributions #include <kern/queue.h> 41*e7776783SApple OSS Distributions 42*e7776783SApple OSS Distributions /* Kernel trace events associated with timers and timer queues */ 43*e7776783SApple OSS Distributions #define DECR_TRAP_LATENCY MACHDBG_CODE(DBG_MACH_EXCP_DECI, 0) 44*e7776783SApple OSS Distributions #define DECR_SET_DEADLINE MACHDBG_CODE(DBG_MACH_EXCP_DECI, 1) 45*e7776783SApple OSS Distributions #define DECR_TIMER_CALLOUT MACHDBG_CODE(DBG_MACH_EXCP_DECI, 2) 46*e7776783SApple OSS Distributions #define DECR_PM_DEADLINE MACHDBG_CODE(DBG_MACH_EXCP_DECI, 3) 47*e7776783SApple OSS Distributions #define DECR_TIMER_MIGRATE MACHDBG_CODE(DBG_MACH_EXCP_DECI, 4) 48*e7776783SApple OSS Distributions #if defined(i386) || defined(x86_64) 49*e7776783SApple OSS Distributions #define DECR_RDHPET MACHDBG_CODE(DBG_MACH_EXCP_DECI, 5) 50*e7776783SApple OSS Distributions #define DECR_SET_TSC_DEADLINE MACHDBG_CODE(DBG_MACH_EXCP_DECI, 6) 51*e7776783SApple OSS Distributions #define DECR_SET_APIC_DEADLINE MACHDBG_CODE(DBG_MACH_EXCP_DECI, 16) 52*e7776783SApple OSS Distributions #endif 53*e7776783SApple OSS Distributions #define DECR_TIMER_ENTER MACHDBG_CODE(DBG_MACH_EXCP_DECI, 7) 54*e7776783SApple OSS Distributions #define DECR_TIMER_CANCEL MACHDBG_CODE(DBG_MACH_EXCP_DECI, 8) 55*e7776783SApple OSS Distributions #define DECR_TIMER_QUEUE MACHDBG_CODE(DBG_MACH_EXCP_DECI, 9) 56*e7776783SApple OSS Distributions #define DECR_TIMER_EXPIRE MACHDBG_CODE(DBG_MACH_EXCP_DECI,10) 57*e7776783SApple OSS Distributions #define DECR_TIMER_ASYNC_DEQ MACHDBG_CODE(DBG_MACH_EXCP_DECI,11) 58*e7776783SApple OSS Distributions #define DECR_TIMER_UPDATE MACHDBG_CODE(DBG_MACH_EXCP_DECI,12) 59*e7776783SApple OSS Distributions #define DECR_TIMER_ESCALATE MACHDBG_CODE(DBG_MACH_EXCP_DECI,13) 60*e7776783SApple OSS Distributions #define DECR_TIMER_OVERDUE MACHDBG_CODE(DBG_MACH_EXCP_DECI,14) 61*e7776783SApple OSS Distributions #define DECR_TIMER_RESCAN MACHDBG_CODE(DBG_MACH_EXCP_DECI,15) 62*e7776783SApple OSS Distributions 63*e7776783SApple OSS Distributions /* 64*e7776783SApple OSS Distributions * Invoked by kernel, implemented by platform. 65*e7776783SApple OSS Distributions */ 66*e7776783SApple OSS Distributions 67*e7776783SApple OSS Distributions /* Request an expiration deadline, returns queue association */ 68*e7776783SApple OSS Distributions extern mpqueue_head_t * timer_queue_assign( 69*e7776783SApple OSS Distributions uint64_t deadline); 70*e7776783SApple OSS Distributions 71*e7776783SApple OSS Distributions extern uint64_t timer_call_slop( 72*e7776783SApple OSS Distributions uint64_t deadline, 73*e7776783SApple OSS Distributions uint64_t armtime, 74*e7776783SApple OSS Distributions uint32_t urgency, 75*e7776783SApple OSS Distributions thread_t arming_thread, 76*e7776783SApple OSS Distributions boolean_t *rlimited); 77*e7776783SApple OSS Distributions extern boolean_t timer_resort_threshold(uint64_t); 78*e7776783SApple OSS Distributions 79*e7776783SApple OSS Distributions /* Cancel an associated expiration deadline and specify new deadline */ 80*e7776783SApple OSS Distributions extern void timer_queue_cancel( 81*e7776783SApple OSS Distributions mpqueue_head_t *queue, 82*e7776783SApple OSS Distributions uint64_t deadline, 83*e7776783SApple OSS Distributions uint64_t new_deadline); 84*e7776783SApple OSS Distributions 85*e7776783SApple OSS Distributions /* Return a pointer to the local timer queue for a given cpu */ 86*e7776783SApple OSS Distributions extern mpqueue_head_t * timer_queue_cpu( 87*e7776783SApple OSS Distributions int cpu); 88*e7776783SApple OSS Distributions 89*e7776783SApple OSS Distributions /* Call a function with argument on a cpu */ 90*e7776783SApple OSS Distributions extern void timer_call_cpu( 91*e7776783SApple OSS Distributions int cpu, 92*e7776783SApple OSS Distributions void (*fn)(void *), 93*e7776783SApple OSS Distributions void *arg); 94*e7776783SApple OSS Distributions 95*e7776783SApple OSS Distributions /* Queue a function to be called with argument on a cpu */ 96*e7776783SApple OSS Distributions extern void timer_call_nosync_cpu( 97*e7776783SApple OSS Distributions int cpu, 98*e7776783SApple OSS Distributions void (*fn)(void *), 99*e7776783SApple OSS Distributions void *arg); 100*e7776783SApple OSS Distributions 101*e7776783SApple OSS Distributions /* 102*e7776783SApple OSS Distributions * Invoked by platform, implemented by kernel. 103*e7776783SApple OSS Distributions */ 104*e7776783SApple OSS Distributions 105*e7776783SApple OSS Distributions /* 106*e7776783SApple OSS Distributions * Invoked by kernel, implemented by platform. 107*e7776783SApple OSS Distributions */ 108*e7776783SApple OSS Distributions 109*e7776783SApple OSS Distributions #define NUM_LATENCY_QOS_TIERS (6) 110*e7776783SApple OSS Distributions 111*e7776783SApple OSS Distributions typedef struct { 112*e7776783SApple OSS Distributions uint32_t idle_entry_timer_processing_hdeadline_threshold_ns; 113*e7776783SApple OSS Distributions uint32_t interrupt_timer_coalescing_ilat_threshold_ns; 114*e7776783SApple OSS Distributions uint32_t timer_resort_threshold_ns; 115*e7776783SApple OSS Distributions 116*e7776783SApple OSS Distributions int32_t timer_coalesce_rt_shift; 117*e7776783SApple OSS Distributions int32_t timer_coalesce_bg_shift; 118*e7776783SApple OSS Distributions int32_t timer_coalesce_kt_shift; 119*e7776783SApple OSS Distributions int32_t timer_coalesce_fp_shift; 120*e7776783SApple OSS Distributions int32_t timer_coalesce_ts_shift; 121*e7776783SApple OSS Distributions 122*e7776783SApple OSS Distributions uint64_t timer_coalesce_rt_ns_max; 123*e7776783SApple OSS Distributions uint64_t timer_coalesce_bg_ns_max; 124*e7776783SApple OSS Distributions uint64_t timer_coalesce_kt_ns_max; 125*e7776783SApple OSS Distributions uint64_t timer_coalesce_fp_ns_max; 126*e7776783SApple OSS Distributions uint64_t timer_coalesce_ts_ns_max; 127*e7776783SApple OSS Distributions 128*e7776783SApple OSS Distributions uint32_t latency_qos_scale[NUM_LATENCY_QOS_TIERS]; 129*e7776783SApple OSS Distributions uint64_t latency_qos_ns_max[NUM_LATENCY_QOS_TIERS]; 130*e7776783SApple OSS Distributions boolean_t latency_tier_rate_limited[NUM_LATENCY_QOS_TIERS]; 131*e7776783SApple OSS Distributions } timer_coalescing_priority_params_ns_t; 132*e7776783SApple OSS Distributions 133*e7776783SApple OSS Distributions extern timer_coalescing_priority_params_ns_t * timer_call_get_priority_params(void); 134*e7776783SApple OSS Distributions 135*e7776783SApple OSS Distributions 136*e7776783SApple OSS Distributions extern uint64_t timer_call_slop( 137*e7776783SApple OSS Distributions uint64_t deadline, 138*e7776783SApple OSS Distributions uint64_t armtime, 139*e7776783SApple OSS Distributions uint32_t urgency, 140*e7776783SApple OSS Distributions thread_t arming_thread, 141*e7776783SApple OSS Distributions boolean_t *rlimited); 142*e7776783SApple OSS Distributions 143*e7776783SApple OSS Distributions /* Process deadline expiration for queue, returns new deadline */ 144*e7776783SApple OSS Distributions extern uint64_t timer_queue_expire( 145*e7776783SApple OSS Distributions mpqueue_head_t *queue, 146*e7776783SApple OSS Distributions uint64_t deadline); 147*e7776783SApple OSS Distributions 148*e7776783SApple OSS Distributions extern uint64_t timer_queue_expire_with_options( 149*e7776783SApple OSS Distributions mpqueue_head_t *, 150*e7776783SApple OSS Distributions uint64_t, 151*e7776783SApple OSS Distributions boolean_t); 152*e7776783SApple OSS Distributions 153*e7776783SApple OSS Distributions /* Shutdown a timer queue and reassign existing activities */ 154*e7776783SApple OSS Distributions extern void timer_queue_shutdown( 155*e7776783SApple OSS Distributions mpqueue_head_t *queue); 156*e7776783SApple OSS Distributions 157*e7776783SApple OSS Distributions /* Move timer requests from one queue to another */ 158*e7776783SApple OSS Distributions extern int timer_queue_migrate( 159*e7776783SApple OSS Distributions mpqueue_head_t *from, 160*e7776783SApple OSS Distributions mpqueue_head_t *to); 161*e7776783SApple OSS Distributions 162*e7776783SApple OSS Distributions /* 163*e7776783SApple OSS Distributions * Invoked by platform, implemented by platfrom. 164*e7776783SApple OSS Distributions */ 165*e7776783SApple OSS Distributions 166*e7776783SApple OSS Distributions extern void timer_intr(int inuser, uint64_t iaddr); 167*e7776783SApple OSS Distributions 168*e7776783SApple OSS Distributions #if defined(i386) || defined(x86_64) 169*e7776783SApple OSS Distributions extern uint64_t setPop(uint64_t time); 170*e7776783SApple OSS Distributions #else 171*e7776783SApple OSS Distributions extern int setPop(uint64_t time); 172*e7776783SApple OSS Distributions #endif 173*e7776783SApple OSS Distributions 174*e7776783SApple OSS Distributions extern void timer_resync_deadlines(void); 175*e7776783SApple OSS Distributions 176*e7776783SApple OSS Distributions extern void timer_queue_expire_local(void *arg); 177*e7776783SApple OSS Distributions 178*e7776783SApple OSS Distributions extern void timer_set_deadline(uint64_t deadline); 179*e7776783SApple OSS Distributions 180*e7776783SApple OSS Distributions /* Migrate the local timer queue of a given cpu to the master cpu */ 181*e7776783SApple OSS Distributions extern uint32_t timer_queue_migrate_cpu(int target_cpu); 182*e7776783SApple OSS Distributions 183*e7776783SApple OSS Distributions extern void timer_queue_trace( 184*e7776783SApple OSS Distributions mpqueue_head_t *queue); 185*e7776783SApple OSS Distributions extern void timer_queue_trace_cpu(int cpu); 186*e7776783SApple OSS Distributions 187*e7776783SApple OSS Distributions extern uint64_t timer_sysctl_get(int oid); 188*e7776783SApple OSS Distributions extern int timer_sysctl_set(int oid, uint64_t value); 189*e7776783SApple OSS Distributions 190*e7776783SApple OSS Distributions #endif /* MACH_KERNEL_PRIVATE */ 191*e7776783SApple OSS Distributions 192*e7776783SApple OSS Distributions #endif /* _KERN_TIMER_QUEUE_H_ */ 193