ThreadState_Aborted = 0x00000100,
} MonoThreadState;
+typedef void (*MonoThreadCleanupFunc) (MonoThread* thread);
extern int mono_thread_get_abort_signal (void);
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 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);
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_ */