X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/15c81e44412415173de220954a453019c68714cd..d9cce835f104d243b0fc0a42cfdb8314181000c9:/src/simix/smx_context.c diff --git a/src/simix/smx_context.c b/src/simix/smx_context.c index 1170709590..94746b7d91 100644 --- a/src/simix/smx_context.c +++ b/src/simix/smx_context.c @@ -18,7 +18,7 @@ XBT_LOG_NEW_DEFAULT_SUBCATEGORY(simix_context, simix, "Context switching mecanism"); char* smx_context_factory_name = NULL; /* factory name specified by --cfg=contexts/factory:value */ -XBT_PUBLIC(smx_ctx_factory_initializer_t) smx_factory_initializer_to_use = NULL; +smx_ctx_factory_initializer_t smx_factory_initializer_to_use = NULL; int smx_context_stack_size = 128 * 1024; #ifdef HAVE_THREAD_LOCAL_STORAGE @@ -136,7 +136,16 @@ XBT_INLINE int SIMIX_context_get_nthreads(void) { * * \param nb_threads the number of threads to use */ -XBT_INLINE void SIMIX_context_set_nthreads(int nb_threads) { +XBT_INLINE void SIMIX_context_set_nthreads(char* str_nb_threads) { + + int nb_threads; + + if(!strcmp(str_nb_threads,"auto")){ + nb_threads = PROCESSOR_COUNT; + XBT_DEBUG("Auto-setting threads to %d",nb_threads); + } + else + nb_threads = atoi(str_nb_threads); xbt_assert(nb_threads > 0, "Invalid number of parallel threads: %d", nb_threads);