]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/kern/thread_call.h
xnu-517.12.7.tar.gz
[apple/xnu.git] / osfmk / kern / thread_call.h
index 0e63edf1cf8c37029b01b2567ec028e859f64454..952265dd9bf7ef25e76e485405f131ceabb2731f 100644 (file)
 #ifndef _KERN_THREAD_CALL_H_
 #define _KERN_THREAD_CALL_H_
 
-#include <libkern/OSBase.h>
+#include <sys/appleapiopts.h>
 
 #include <mach/mach_types.h>
 
+#include <kern/clock.h>
+
 typedef struct call_entry      *thread_call_t;
 typedef void                           *thread_call_param_t;
 typedef void                           (*thread_call_func_t)(
@@ -57,13 +59,13 @@ thread_call_enter1(
 boolean_t
 thread_call_enter_delayed(
        thread_call_t           call,
-       AbsoluteTime            deadline
+       uint64_t                        deadline
 );
 boolean_t
 thread_call_enter1_delayed(
        thread_call_t                   call,
        thread_call_param_t             param1,
-       AbsoluteTime                    deadline
+       uint64_t                                deadline
 );
 boolean_t
 thread_call_cancel(
@@ -72,7 +74,7 @@ thread_call_cancel(
 boolean_t
 thread_call_is_delayed(
        thread_call_t           call,
-       AbsoluteTime            *deadline
+       uint64_t                        *deadline
 );
 
 thread_call_t
@@ -85,11 +87,16 @@ thread_call_free(
        thread_call_t           call
 );
 
+#ifdef __APPLE_API_PRIVATE
+
+#ifdef __APPLE_API_OBSOLETE
+
 /*
  * This portion of the interface
  * is OBSOLETE and DEPRECATED.  It
  * will disappear shortly.
  */
+
 void
 thread_call_func(
        thread_call_func_t              func,
@@ -100,7 +107,7 @@ void
 thread_call_func_delayed(
        thread_call_func_t              func,
        thread_call_param_t             param,
-       AbsoluteTime                    deadline
+       uint64_t                                deadline
 );
 
 boolean_t
@@ -109,8 +116,11 @@ thread_call_func_cancel(
        thread_call_param_t             param,
        boolean_t                               cancel_all
 );
+
 /* End OBSOLETE and DEPRECATED */
 
+#endif /* __APPLE_API_OBSOLETE */
+
 #ifdef MACH_KERNEL_PRIVATE
 #include <kern/call_entry.h>
 
@@ -126,6 +136,30 @@ thread_call_setup(
        thread_call_param_t             param0
 );
 
+void
+call_thread_block(void),
+call_thread_unblock(void);
+
 #endif /* MACH_KERNEL_PRIVATE */
 
+#endif /* __APPLE_API_PRIVATE */
+
+#if            !defined(MACH_KERNEL_PRIVATE) && !defined(ABSOLUTETIME_SCALAR_TYPE)
+
+#include <libkern/OSBase.h>
+
+#define thread_call_enter_delayed(a, b)        \
+       thread_call_enter_delayed((a), __OSAbsoluteTime(b))
+
+#define thread_call_enter1_delayed(a, b, c)    \
+       thread_call_enter1_delayed((a), (b), __OSAbsoluteTime(c))
+
+#define thread_call_is_delayed(a, b)   \
+       thread_call_is_delayed((a), __OSAbsoluteTimePtr(b))
+
+#define thread_call_func_delayed(a, b, c)      \
+       thread_call_func_delayed((a), (b), __OSAbsoluteTime(c))
+
+#endif
+
 #endif /* _KERN_THREAD_CALL_H_ */