X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/5c8ede40c4f5e920bd12b2e4ede74db2892e0d60..8e06878d622c1792c5e7d8d2d412241b53004e37:/include/smpi/smpi_cocci.h diff --git a/include/smpi/smpi_cocci.h b/include/smpi/smpi_cocci.h index 29daeec643..bcd150d3c8 100644 --- a/include/smpi/smpi_cocci.h +++ b/include/smpi/smpi_cocci.h @@ -7,10 +7,12 @@ #ifndef SMPI_COCCI_H #define SMPI_COCCI_H +#include + /* Macros used by coccinelle-generated code */ -#define SMPI_INITIALIZE_GLOBAL(name,type) \ - NULL; \ +#define SMPI_VARINIT_GLOBAL(name,type) \ +type *name = NULL; \ void __attribute__((weak,constructor)) __preinit_##name(void) { \ if(!name) \ name = (type*)malloc(smpi_global_size() * sizeof(type)); \ @@ -20,8 +22,8 @@ void __attribute__((weak,destructor)) __postfini_##name(void) { \ name = NULL; \ } -#define SMPI_INITIALIZE_AND_SET_GLOBAl(name,type,expr) \ - NULL; \ +#define SMPI_VARINIT_GLOBAL_AND_SET(name,type,expr) \ +type *name = NULL; \ void __attribute__((weak,constructor)) __preinit_##name(void) { \ size_t size = smpi_global_size(); \ size_t i; \ @@ -38,6 +40,32 @@ void __attribute__((weak,destructor)) __postfini_##name(void) { \ name = NULL; \ } -#define SMPI_GLOBAL_VAR_LOCAL_ACCESS(name) name[smpi_process_index()] +#define SMPI_VARGET_GLOBAL(name) name[smpi_process_index()] + +/* The following handle local static variables */ + +XBT_PUBLIC(void) smpi_register_static(void* arg); + +#define SMPI_VARINIT_STATIC(name,type) \ +static type *name = NULL; \ +if(!name) { \ + name = (type*)malloc(smpi_global_size() * sizeof(type)); \ + smpi_register_static(name); \ +} + +#define SMPI_VARINIT_STATIC_AND_SET(name,type,expr) \ +static type *name = NULL; \ +if(!name) { \ + size_t size = smpi_global_size(); \ + size_t i; \ + type value = expr; \ + name = (type*)malloc(size * sizeof(type)); \ + for(i = 0; i < size; i++) { \ + name[i] = value; \ + } \ + smpi_register_static(name); \ +} + +#define SMPI_VARGET_STATIC(name) name[smpi_process_index()] #endif