2 * runtime.c: Runtime functions
7 * Copyright 2010 Novell, Inc (http://www.novell.com)
8 * Licensed under the MIT license. See LICENSE file in the project root for full license information.
15 #include <mono/metadata/appdomain.h>
16 #include <mono/metadata/class.h>
17 #include <mono/metadata/class-internals.h>
18 #include <mono/metadata/runtime.h>
19 #include <mono/metadata/monitor.h>
20 #include <mono/metadata/threads-types.h>
21 #include <mono/metadata/threadpool-ms.h>
22 #include <mono/metadata/marshal.h>
23 #include <mono/utils/atomic.h>
25 static gboolean shutting_down_inited = FALSE;
26 static gboolean shutting_down = FALSE;
29 * mono_runtime_set_shutting_down:
31 * Invoked by System.Environment.Exit to flag that the runtime
34 * Deprecated. This function can break the shutdown sequence.
37 mono_runtime_set_shutting_down (void)
43 * mono_runtime_is_shutting_down:
45 * Returns whether the runtime has been flagged for shutdown.
47 * This is consumed by the P:System.Environment.HasShutdownStarted
52 mono_runtime_is_shutting_down (void)
58 fire_process_exit_event (MonoDomain *domain, gpointer user_data)
60 MonoClassField *field;
62 MonoObject *delegate, *exc;
64 field = mono_class_get_field_from_name (mono_defaults.appdomain_class, "ProcessExit");
67 delegate = *(MonoObject **)(((char *)domain->domain) + field->offset);
73 mono_runtime_delegate_invoke (delegate, pa, &exc);
77 mono_runtime_fire_process_exit_event (void)
79 #ifndef MONO_CROSS_COMPILE
80 mono_domain_foreach (fire_process_exit_event, NULL);
86 * mono_runtime_try_shutdown:
88 * Try to initialize runtime shutdown.
90 * After this call completes the thread pool will stop accepting new jobs and no further threads will be created.
92 * Returns: TRUE if shutdown was initiated by this call or false is other thread beat this one.
95 mono_runtime_try_shutdown (void)
97 if (InterlockedCompareExchange (&shutting_down_inited, TRUE, FALSE))
100 mono_runtime_fire_process_exit_event ();
102 shutting_down = TRUE;
104 mono_threads_set_shutting_down ();
106 /* No new threads will be created after this point */
108 mono_runtime_set_shutting_down ();
110 /* This will kill the tp threads which cannot be suspended */
111 mono_threadpool_ms_cleanup ();
113 /*TODO move the follow to here:
114 mono_thread_suspend_all_other_threads (); OR mono_thread_wait_all_other_threads
116 mono_runtime_quit ();
124 mono_runtime_is_critical_method (MonoMethod *method)
130 Coordinate the creation of all remaining TLS slots in the runtime.
131 No further TLS slots should be created after this function finishes.
132 This restriction exists because AOT requires offsets to be constant
136 mono_runtime_init_tls (void)
138 mono_marshal_init_tls ();
139 mono_thread_init_tls ();