grammar updates
[mono.git] / mono / metadata / threads.h
index faecc11166af6ee6b2f41c3d1e41a7b62f149489..d801502d9e08df207cd51baa1cf4c135320477d8 100644 (file)
@@ -28,6 +28,7 @@ typedef enum {
        ThreadState_Aborted = 0x00000100,
 } MonoThreadState;
 
+typedef void (*MonoThreadCleanupFunc) (MonoThread* thread);
 
 extern int  mono_thread_get_abort_signal (void);
 
@@ -36,10 +37,18 @@ extern void mono_thread_init (MonoThreadStartCB start_cb,
 extern void mono_thread_manage(void);
 extern void mono_thread_abort_all_other_threads (void);
 
+extern void mono_thread_push_appdomain_ref (MonoDomain *domain);
+extern void mono_thread_pop_appdomain_ref (void);
+
+extern MonoException * mono_thread_get_pending_exception (void);
+
+extern gboolean mono_threads_abort_appdomain_threads (MonoDomain *domain, int timeout);
+
 extern MonoThread *mono_thread_current (void);
 
 typedef struct {
        gpointer (* thread_start_compile_func) (MonoMethod *delegate);
+       void (* thread_created) (guint32 tid, gpointer stack_start, gpointer func);
        void (* start_resume) (guint32 tid);
        void (* end_resume) (guint32 tid);
 } MonoThreadCallbacks;
@@ -52,6 +61,17 @@ extern void mono_thread_create (MonoDomain *domain, gpointer func,
                                       gpointer arg);
 extern MonoThread *mono_thread_attach (MonoDomain *domain);
 
+void     mono_threads_install_cleanup   (MonoThreadCleanupFunc func);
+
+extern void mono_threads_set_default_stacksize (guint32 stacksize);
+extern guint32 mono_threads_get_default_stacksize (void);
+guint32  mono_threads_alloc_static_data (guint32 size, guint32 align);
+gpointer mono_threads_get_static_data   (guint32 offset);
+
+void mono_gc_stop_world (void);
+
+void mono_gc_start_world (void);
+
 extern HANDLE ves_icall_System_Threading_Thread_Thread_internal(MonoThread *this_obj, MonoObject *start);
 extern void ves_icall_System_Threading_Thread_Thread_free_internal(MonoThread *this_obj, HANDLE thread);
 extern void ves_icall_System_Threading_Thread_Start_internal(MonoThread *this_obj, HANDLE thread);
@@ -66,6 +86,7 @@ extern void ves_icall_System_Threading_Mutex_ReleaseMutex_internal (HANDLE handl
 extern HANDLE ves_icall_System_Threading_Events_CreateEvent_internal (MonoBoolean manual,MonoBoolean initial,char *name);
 extern gboolean ves_icall_System_Threading_Events_SetEvent_internal (HANDLE handle);
 extern gboolean ves_icall_System_Threading_Events_ResetEvent_internal (HANDLE handle);
+extern void ves_icall_System_Threading_Events_CloseEvent_internal (HANDLE handle);
 
 extern gboolean ves_icall_System_Threading_WaitHandle_WaitAll_internal(MonoArray *mono_handles, gint32 ms, gboolean exitContext);
 extern gint32 ves_icall_System_Threading_WaitHandle_WaitAny_internal(MonoArray *mono_handles, gint32 ms, gboolean exitContext);
@@ -85,6 +106,8 @@ extern MonoObject *ves_icall_System_Threading_Interlocked_CompareExchange_Object
 extern gfloat ves_icall_System_Threading_Interlocked_CompareExchange_Single(gfloat *location1, gfloat value, gfloat comparand);
 extern void ves_icall_System_Threading_Thread_Abort (MonoThread *thread, MonoObject *state);
 extern void ves_icall_System_Threading_Thread_ResetAbort (void);
+extern void ves_icall_System_Threading_ThreadPool_GetAvailableThreads (int *workerThreads, int *completionPortThreads);
+extern void ves_icall_System_Threading_ThreadPool_GetMaxThreads (int *workerThreads, int *completionPortThreads);
 
 
 #endif /* _MONO_METADATA_THREADS_H_ */