- /* if a factory is already instantiated (SIMIX_context_mod_init() was called) */
- if (simix_global->context_factory != NULL) {
- /* if the desired factory is different of the current factory, call SIMIX_context_mod_exit() */
- if (strcmp(simix_global->context_factory->name, name))
- SIMIX_context_mod_exit();
- else
- /* the same context factory is requested return directly */
- return 0;
- }
-
- /* get the desired factory */
- SIMIX_context_init_factory_by_name(&simix_global->context_factory, name);
-
- /* maestro process specialisation */
- (*(simix_global->context_factory->create_maestro_context)) (&simix_global->maestro_process);
-
- /* the current process is the process of the maestro */
- simix_global->current_process = simix_global->maestro_process;
-
- /* the current context doesn't want to die */
- simix_global->current_process->iwannadie = 0;
-
- /* insert the current context in the list of the contexts in use */
- xbt_swag_insert(simix_global->current_process, simix_global->process_list);
-
- return 0;
+#ifdef HAVE_THREAD_LOCAL_STORAGE
+ return smx_current_context;
+#else
+ return xbt_os_thread_get_specific(smx_current_context_key);
+#endif