X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/a2a013c0e4ca407feeb7b3d0e85abba7acae2532..5e3adb6026f929615076da0e5a32dc35a02db573:/src/simix/Context.cpp diff --git a/src/simix/Context.cpp b/src/simix/Context.cpp deleted file mode 100644 index 5817bc74e6..0000000000 --- a/src/simix/Context.cpp +++ /dev/null @@ -1,107 +0,0 @@ -/* Copyright (c) 2007-2010, 2012-2015. The SimGrid Team. - * All rights reserved. */ - -/* This program is free software; you can redistribute it and/or modify it - * under the terms of the license (GNU LGPL) which comes with this package. */ - -#include - -#include -#include -#include - -#include - -#include "mc/mc.h" - -#include "src/simix/smx_private.h" - -void SIMIX_process_set_cleanup_function( - smx_process_t process, void_pfn_smxprocess_t cleanup) -{ - process->context->set_cleanup(cleanup); -} - -/** - * @brief creates a new context for a user level process - * @param code a main function - * @param cleanup_func the function to call when the context stops - */ -smx_context_t SIMIX_context_new( - std::function code, - void_pfn_smxprocess_t cleanup_func, - smx_process_t simix_process) -{ - if (!simix_global) - xbt_die("simix is not initialized, please call MSG_init first"); - return simix_global->context_factory->create_context( - std::move(code), cleanup_func, simix_process); -} - -namespace simgrid { -namespace simix { - -ContextFactoryInitializer factory_initializer = nullptr; - -ContextFactory::~ContextFactory() {} - -Context* ContextFactory::self() -{ - return SIMIX_context_get_current(); -} - -void ContextFactory::declare_context(void* context, std::size_t size) -{ -#if HAVE_MC - /* Store the address of the stack in heap to compare it apart of heap comparison */ - if(MC_is_active()) - MC_ignore_heap(context, size); -#endif -} - -Context* ContextFactory::attach(void_pfn_smxprocess_t cleanup_func, smx_process_t process) -{ - xbt_die("Cannot attach with this ContextFactory.\n" - "Try using --cfg=contexts/factory:thread instead.\n"); -} - -Context* ContextFactory::create_maestro(std::function code, smx_process_t process) -{ - xbt_die("Cannot create_maestro with this ContextFactory.\n" - "Try using --cfg=contexts/factory:thread instead.\n"); -} - -Context::Context(std::function code, - void_pfn_smxprocess_t cleanup_func, smx_process_t process) - : code_(std::move(code)), process_(process), iwannadie(false) -{ - /* If the user provided a function for the process then use it. - Otherwise, it is the context for maestro and we should set it as the - current context */ - if (has_code()) - this->cleanup_func_ = cleanup_func; - else - SIMIX_context_set_current(this); -} - -Context::~Context() -{ -} - -void Context::stop() -{ - if (this->cleanup_func_) - this->cleanup_func_(this->process_); - this->process_->suspended = 0; - - this->iwannadie = false; - simcall_process_cleanup(this->process_); - this->iwannadie = true; -} - -AttachContext::~AttachContext() -{ -} - -} -}