/ duct-tape / xnu / osfmk / kern / clock.h
clock.h
  1  /*
  2   * Copyright (c) 2000-2008 Apple Inc. All rights reserved.
  3   *
  4   * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  5   *
  6   * This file contains Original Code and/or Modifications of Original Code
  7   * as defined in and that are subject to the Apple Public Source License
  8   * Version 2.0 (the 'License'). You may not use this file except in
  9   * compliance with the License. The rights granted to you under the License
 10   * may not be used to create, or enable the creation or redistribution of,
 11   * unlawful or unlicensed copies of an Apple operating system, or to
 12   * circumvent, violate, or enable the circumvention or violation of, any
 13   * terms of an Apple operating system software license agreement.
 14   *
 15   * Please obtain a copy of the License at
 16   * http://www.opensource.apple.com/apsl/ and read it before using this file.
 17   *
 18   * The Original Code and all software distributed under the License are
 19   * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
 20   * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
 21   * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
 22   * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
 23   * Please see the License for the specific language governing rights and
 24   * limitations under the License.
 25   *
 26   * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
 27   */
 28  /*
 29   * @OSF_COPYRIGHT@
 30   */
 31  /*
 32   */
 33  
 34  #ifndef _KERN_CLOCK_H_
 35  #define _KERN_CLOCK_H_
 36  
 37  #include <stdint.h>
 38  #include <mach/mach_types.h>
 39  #include <mach/clock_types.h>
 40  #include <mach/message.h>
 41  #include <mach/mach_time.h>
 42  #include <mach/boolean.h>
 43  
 44  #include <kern/kern_types.h>
 45  
 46  #include <sys/cdefs.h>
 47  
 48  
 49  #ifdef  __LP64__
 50  
 51  typedef unsigned long           clock_sec_t;
 52  typedef unsigned int            clock_usec_t, clock_nsec_t;
 53  
 54  #else   /* __LP64__ */
 55  
 56  typedef uint32_t                        clock_sec_t;
 57  typedef uint32_t                        clock_usec_t, clock_nsec_t;
 58  
 59  #endif  /* __LP64__ */
 60  
 61  #ifdef  MACH_KERNEL_PRIVATE
 62  
 63  #include <kern/queue.h>
 64  
 65  /*
 66   * Clock operations list structure. Contains vectors to machine
 67   * dependent clock routines.
 68   */
 69  struct  clock_ops {
 70  	int             (*c_config)(void);              /* configuration */
 71  
 72  	int             (*c_init)(void);                /* initialize */
 73  
 74  	kern_return_t   (*c_gettime)(   /* get time */
 75  		mach_timespec_t                 *cur_time);
 76  
 77  	kern_return_t   (*c_getattr)(   /* get attributes */
 78  		clock_flavor_t                  flavor,
 79  		clock_attr_t                    attr,
 80  		mach_msg_type_number_t  *count);
 81  };
 82  typedef const struct clock_ops  *clock_ops_t;
 83  typedef struct clock_ops        clock_ops_data_t;
 84  
 85  /*
 86   * Actual clock object data structure. Contains the machine
 87   * dependent operations list and clock operation ports.
 88   */
 89  struct  clock {
 90  	clock_ops_t             cl_ops;         /* operations list */
 91  	struct ipc_port         *cl_service;    /* service port */
 92  	struct ipc_port         *cl_control;    /* control port */
 93  };
 94  typedef struct clock            clock_data_t;
 95  
 96  /*
 97   * Configure the clock system.
 98   */
 99  extern void             clock_config(void);
100  extern void             clock_oldconfig(void);
101  
102  /*
103   * Initialize the clock system.
104   */
105  extern void             clock_init(void);
106  extern void             clock_oldinit(void);
107  
108  extern void             clock_timebase_init(void);
109  
110  /*
111   * Initialize the clock ipc service facility.
112   */
113  extern void             clock_service_create(void);
114  
115  extern void clock_gettimeofday_set_commpage(
116  	uint64_t                                abstime,
117  	uint64_t                                sec,
118  	uint64_t                                frac,
119  	uint64_t                                scale,
120  	uint64_t                                tick_per_sec);
121  
122  extern void                     machine_delay_until(uint64_t interval,
123      uint64_t                deadline);
124  
125  extern uint32_t         hz_tick_interval;
126  
127  extern void             nanotime_to_absolutetime(
128  	clock_sec_t             secs,
129  	clock_nsec_t    nanosecs,
130  	uint64_t                *result);
131  
132  #endif /* MACH_KERNEL_PRIVATE */
133  
134  __BEGIN_DECLS
135  
136  #ifdef  XNU_KERNEL_PRIVATE
137  
138  extern void                     clock_adjtime(
139  	long            *secs,
140  	int                     *microsecs);
141  
142  extern void                     clock_initialize_calendar(void);
143  
144  extern void                     clock_wakeup_calendar(void);
145  
146  extern void                     clock_update_calendar(void);
147  
148  extern void                     clock_get_calendar_uptime(clock_sec_t           *secs);
149  
150  extern void clock_gettimeofday_new(clock_sec_t          *secs,
151      clock_usec_t    *microsecs);
152  extern void                     clock_gettimeofday(
153  	clock_sec_t                     *secs,
154  	clock_usec_t            *microsecs);
155  
156  extern void                     clock_gettimeofday_and_absolute_time(
157  	clock_sec_t                     *secs,
158  	clock_usec_t            *microsecs,
159  	uint64_t                        *absolute_time);
160  
161  
162  extern void                     clock_set_calendar_microtime(
163  	clock_sec_t                     secs,
164  	clock_usec_t            microsecs);
165  
166  extern void                     clock_get_boottime_nanotime(
167  	clock_sec_t                     *secs,
168  	clock_nsec_t            *nanosecs);
169  
170  extern void                     clock_get_boottime_microtime(
171  	clock_sec_t                     *secs,
172  	clock_nsec_t            *microsecs);
173  
174  extern void                     absolutetime_to_microtime(
175  	uint64_t                        abstime,
176  	clock_sec_t                     *secs,
177  	clock_usec_t            *microsecs);
178  
179  extern void                     clock_deadline_for_periodic_event(
180  	uint64_t                        interval,
181  	uint64_t                        abstime,
182  	uint64_t                        *deadline);
183  
184  #if     CONFIG_DTRACE
185  
186  extern void                     clock_get_calendar_nanotime_nowait(
187  	clock_sec_t                     *secs,
188  	clock_nsec_t            *nanosecs);
189  
190  #endif  /* CONFIG_DTRACE */
191  
192  boolean_t kdp_clock_is_locked(void);
193  
194  #endif  /* XNU_KERNEL_PRIVATE */
195  
196  extern void                     clock_get_calendar_microtime(
197  	clock_sec_t                     *secs,
198  	clock_usec_t            *microsecs);
199  
200  extern void                     clock_get_calendar_absolute_and_microtime(
201  	clock_sec_t                     *secs,
202  	clock_usec_t            *microsecs,
203  	uint64_t                *abstime);
204  
205  extern void                     clock_get_calendar_nanotime(
206  	clock_sec_t                     *secs,
207  	clock_nsec_t            *nanosecs);
208  
209  extern void                     clock_get_system_microtime(
210  	clock_sec_t                     *secs,
211  	clock_usec_t            *microsecs);
212  
213  extern void                     clock_get_system_nanotime(
214  	clock_sec_t                     *secs,
215  	clock_nsec_t            *nanosecs);
216  
217  extern void                             clock_timebase_info(
218  	mach_timebase_info_t    info);
219  
220  extern void                             clock_get_uptime(
221  	uint64_t                *result);
222  
223  extern void                             clock_interval_to_deadline(
224  	uint32_t                interval,
225  	uint32_t                scale_factor,
226  	uint64_t                *result);
227  
228  extern void                             nanoseconds_to_deadline(
229  	uint64_t                interval,
230  	uint64_t                *result);
231  
232  extern void                             clock_interval_to_absolutetime_interval(
233  	uint32_t                interval,
234  	uint32_t                scale_factor,
235  	uint64_t                *result);
236  
237  extern void                             clock_absolutetime_interval_to_deadline(
238  	uint64_t                abstime,
239  	uint64_t                *result);
240  
241  extern void                             clock_continuoustime_interval_to_deadline(
242  	uint64_t                abstime,
243  	uint64_t                *result);
244  
245  extern void                             clock_delay_until(
246  	uint64_t                deadline);
247  
248  extern void                             absolutetime_to_nanoseconds(
249  	uint64_t                abstime,
250  	uint64_t                *result);
251  
252  extern void                             nanoseconds_to_absolutetime(
253  	uint64_t                nanoseconds,
254  	uint64_t                *result);
255  
256  /*
257   * Absolute <-> Continuous Time conversion routines
258   *
259   * It is the caller's responsibility to ensure that these functions are
260   * synchronized with respect to updates to the continuous timebase.  The
261   * returned value is only valid until the next update to the continuous
262   * timebase.
263   *
264   * If the value to be returned by continuoustime_to_absolutetime would be
265   * negative, zero is returned.  This occurs when the provided continuous time
266   * is less the amount of the time the system spent asleep and /must/ be
267   * handled.
268   */
269  extern uint64_t                 absolutetime_to_continuoustime(
270  	uint64_t                abstime);
271  extern uint64_t                 continuoustime_to_absolutetime(
272  	uint64_t                conttime);
273  
274  extern uint64_t mach_absolutetime_asleep;
275  extern uint64_t mach_absolutetime_last_sleep;
276  #if HIBERNATION && HAS_CONTINUOUS_HWCLOCK
277  extern uint64_t hwclock_conttime_offset;
278  #endif
279  
280  #ifdef  KERNEL_PRIVATE
281  
282  /*
283   * Obsolete interfaces.
284   */
285  
286  #ifndef __LP64__
287  
288  #define MACH_TIMESPEC_SEC_MAX           (0 - 1)
289  #define MACH_TIMESPEC_NSEC_MAX          (NSEC_PER_SEC - 1)
290  
291  #define MACH_TIMESPEC_MAX       ((mach_timespec_t) {                            \
292  	                                                                MACH_TIMESPEC_SEC_MAX,          \
293  	                                                                MACH_TIMESPEC_NSEC_MAX } )
294  #define MACH_TIMESPEC_ZERO      ((mach_timespec_t) { 0, 0 } )
295  
296  #define ADD_MACH_TIMESPEC_NSEC(t1, nsec)                \
297    do {                                                                                  \
298  	(t1)->tv_nsec += (clock_res_t)(nsec);           \
299  	if ((clock_res_t)(nsec) > 0 &&                          \
300  	                (t1)->tv_nsec >= NSEC_PER_SEC) {        \
301  	        (t1)->tv_nsec -= NSEC_PER_SEC;                  \
302  	        (t1)->tv_sec += 1;                                              \
303  	}                                                                                       \
304  	else if ((clock_res_t)(nsec) < 0 &&                     \
305  	                         (t1)->tv_nsec < 0) {                   \
306  	        (t1)->tv_nsec += NSEC_PER_SEC;                  \
307  	        (t1)->tv_sec -= 1;                                              \
308  	}                                                                                       \
309    } while (0)
310  
311  #include <Availability.h>
312  
313  /* Use mach_absolute_time() */
314  extern mach_timespec_t  clock_get_system_value(void) __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_8, __IPHONE_2_0, __IPHONE_6_0);
315  
316  extern mach_timespec_t  clock_get_calendar_value(void) __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_8, __IPHONE_2_0, __IPHONE_6_0);
317  
318  #else   /* __LP64__ */
319  
320  #ifdef  XNU_KERNEL_PRIVATE
321  
322  #define MACH_TIMESPEC_ZERO      ((mach_timespec_t) { 0, 0 } )
323  
324  #endif  /* XNU_KERNEL_PRIVATE */
325  
326  #endif  /* __LP64__ */
327  
328  extern void                             delay_for_interval(
329  	uint32_t                interval,
330  	uint32_t                scale_factor);
331  
332  extern void                             delay_for_interval_with_leeway(
333  	uint32_t                interval,
334  	uint32_t                leeway,
335  	uint32_t                scale_factor);
336  
337  #ifdef  XNU_KERNEL_PRIVATE
338  extern void delay(int usec);
339  #endif  /* XNU_KERNEL_PRIVATE */
340  
341  #endif  /* KERNEL_PRIVATE */
342  
343  __END_DECLS
344  
345  #endif  /* _KERN_CLOCK_H_ */