1
1

oshmem: memheap: refactor component selection code

Do not call component's init function until the component has been
selected.

Use mca_base_select() instead of the custom component selection code.

Signed-off-by: Alex Mikheev <alexm@mellanox.com>
Этот коммит содержится в:
Alex Mikheev 2017-01-15 16:09:38 +02:00
родитель 6d59b476de
Коммит 83c2ab76a5
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: 0F964A1EF0579522
6 изменённых файлов: 41 добавлений и 182 удалений

Просмотреть файл

@ -31,7 +31,6 @@ OSHMEM_DECLSPEC int mca_memheap_base_select(void);
/* /*
* Globals * Globals
*/ */
OSHMEM_DECLSPEC extern struct mca_memheap_base_module_t* mca_memheap_base_module_initialized;
/* only used within base -- no need to DECLSPEC */ /* only used within base -- no need to DECLSPEC */
#define MEMHEAP_BASE_MIN_ORDER 3 /* forces 64 bit alignment */ #define MEMHEAP_BASE_MIN_ORDER 3 /* forces 64 bit alignment */
@ -39,8 +38,6 @@ OSHMEM_DECLSPEC extern struct mca_memheap_base_module_t* mca_memheap_base_module
#define MEMHEAP_BASE_PRIVATE_SIZE (1ULL << MEMHEAP_BASE_PAGE_ORDER) /* should be at least the same as a huge page size */ #define MEMHEAP_BASE_PRIVATE_SIZE (1ULL << MEMHEAP_BASE_PAGE_ORDER) /* should be at least the same as a huge page size */
#define MEMHEAP_BASE_MIN_SIZE (1ULL << MEMHEAP_BASE_PAGE_ORDER) /* must fit into at least one huge page */ #define MEMHEAP_BASE_MIN_SIZE (1ULL << MEMHEAP_BASE_PAGE_ORDER) /* must fit into at least one huge page */
extern char* mca_memheap_base_include;
extern char* mca_memheap_base_exclude;
extern int mca_memheap_base_already_opened; extern int mca_memheap_base_already_opened;
extern int mca_memheap_base_key_exchange; extern int mca_memheap_base_key_exchange;

Просмотреть файл

@ -33,10 +33,7 @@
int mca_memheap_base_output = -1; int mca_memheap_base_output = -1;
int mca_memheap_base_key_exchange = 1; int mca_memheap_base_key_exchange = 1;
char* mca_memheap_base_include = NULL;
char* mca_memheap_base_exclude = NULL;
opal_list_t mca_memheap_base_components_opened = {{0}}; opal_list_t mca_memheap_base_components_opened = {{0}};
struct mca_memheap_base_module_t* mca_memheap_base_module_initialized = NULL;
int mca_memheap_base_already_opened = 0; int mca_memheap_base_already_opened = 0;
mca_memheap_map_t mca_memheap_base_map = {{{{0}}}}; mca_memheap_map_t mca_memheap_base_map = {{{{0}}}};
@ -55,39 +52,6 @@ static int mca_memheap_base_register(mca_base_register_flag_t flags)
MCA_BASE_VAR_SCOPE_READONLY, MCA_BASE_VAR_SCOPE_READONLY,
&mca_memheap_base_key_exchange); &mca_memheap_base_key_exchange);
(void) mca_base_var_register("oshmem",
"memheap",
"base",
"include",
"Specify a specific MEMHEAP implementation to use",
MCA_BASE_VAR_TYPE_STRING,
NULL,
0,
MCA_BASE_VAR_FLAG_SETTABLE,
OPAL_INFO_LVL_9,
MCA_BASE_VAR_SCOPE_READONLY,
&mca_memheap_base_include);
if (NULL == mca_memheap_base_include) {
mca_memheap_base_include = getenv(SHMEM_HEAP_TYPE);
if (NULL == mca_memheap_base_include)
mca_memheap_base_include = strdup("");
else
mca_memheap_base_include = strdup(mca_memheap_base_include);
}
(void) mca_base_var_register("oshmem",
"memheap",
"base",
"exclude",
"Specify excluded MEMHEAP implementations",
MCA_BASE_VAR_TYPE_STRING,
NULL,
0,
MCA_BASE_VAR_FLAG_SETTABLE,
OPAL_INFO_LVL_9,
MCA_BASE_VAR_SCOPE_READONLY,
&mca_memheap_base_exclude);
return OSHMEM_SUCCESS; return OSHMEM_SUCCESS;
} }

Просмотреть файл

@ -45,133 +45,43 @@ static memheap_context_t* _memheap_create(void);
*/ */
int mca_memheap_base_select() int mca_memheap_base_select()
{ {
int priority = 0; int best_priority;
int max_priority = 0; memheap_context_t *context;
mca_base_component_list_item_t *cli, *next; mca_memheap_base_component_t *best_component = NULL;
mca_memheap_base_component_t *component = NULL; mca_memheap_base_module_t *best_module = NULL;
mca_memheap_base_component_t *max_priority_component = NULL;
mca_memheap_base_module_t *module = NULL;
memheap_context_t *context = NULL;
char** include = opal_argv_split(mca_memheap_base_include, ','); if( OPAL_SUCCESS != mca_base_select("memheap", oshmem_memheap_base_framework.framework_output,
char** exclude = opal_argv_split(mca_memheap_base_exclude, ','); &oshmem_memheap_base_framework.framework_components,
(mca_base_module_t **) &best_module,
(mca_base_component_t **) &best_component,
&best_priority) ) {
return OSHMEM_ERROR;
}
context = _memheap_create(); context = _memheap_create();
if (!context) { if (NULL == context) {
opal_argv_free(include);
opal_argv_free(exclude);
return OSHMEM_ERROR; return OSHMEM_ERROR;
} }
OPAL_LIST_FOREACH_SAFE(cli, next, &oshmem_memheap_base_framework.framework_components, mca_base_component_list_item_t) { if (OSHMEM_SUCCESS != best_component->memheap_init(context)) {
component = (mca_memheap_base_component_t *) cli->cli_component;
/* Verify if the component is in the include or the exclude list. */
/* If there is an include list - item must be in the list to be included */
if (NULL != include) {
char** argv = include;
bool found = false;
while (argv && *argv) {
if (strcmp(component->memheap_version.mca_component_name, *argv)
== 0) {
found = true;
break;
}
argv++;
}
/* If not in the list do not choose this component */
if (found == false) {
continue;
}
/* Otherwise - check the exclude list to see if this item has been specifically excluded */
} else if (NULL != exclude) {
char** argv = exclude;
bool found = false;
while (argv && *argv) {
if (strcmp(component->memheap_version.mca_component_name, *argv)
== 0) {
found = true;
break;
}
argv++;
}
if (found == true) {
continue;
}
}
/* Verify that the component has an init function */
if (NULL == component->memheap_init) {
MEMHEAP_VERBOSE(10,
"select: no init function; for component %s. No component selected",
component->memheap_version.mca_component_name);
} else {
MEMHEAP_VERBOSE(5,
"select: component %s size : user %d private: %d",
component->memheap_version.mca_component_name, (int)context->user_size, (int)context->private_size);
/* Init the component in order to get its priority */
module = component->memheap_init(context, &priority);
/* If the component didn't initialize, remove it from the opened list, remove it from the component repository and return an error */
if (NULL == module) {
MEMHEAP_VERBOSE(10,
"select: init of component %s returned failure",
component->memheap_version.mca_component_name);
opal_list_remove_item(&oshmem_memheap_base_framework.framework_components, &cli->super);
mca_base_component_close((mca_base_component_t *) component,
oshmem_memheap_base_framework.framework_output);
} else {
/* Calculate memheap size in case it was not set during component initialization */
module->memheap_size = context->user_size;
}
}
/* Init max priority component */
if (NULL == max_priority_component) {
max_priority_component = component;
mca_memheap_base_module_initialized = module;
max_priority = priority;
}
/* Update max priority component if current component has greater priority */
if (priority > max_priority) {
max_priority = priority;
max_priority_component = component;
mca_memheap_base_module_initialized = module;
}
}
opal_argv_free(include);
opal_argv_free(exclude);
/* Verify that a component was selected */
if (NULL == max_priority_component) {
MEMHEAP_VERBOSE(10, "select: no component selected");
return OSHMEM_ERROR;
}
/* Verify that some module was initialized */
if (NULL == mca_memheap_base_module_initialized) {
opal_show_help("help-oshmem-memheap.txt", opal_show_help("help-oshmem-memheap.txt",
"find-available:none-found", "find-available:none-found",
true, true,
"memheap"); "memheap");
orte_errmgr.abort(1, NULL ); return OSHMEM_ERROR;
} }
/* Calculate memheap size in case it was not set during component initialization */
best_module->memheap_size = context->user_size;
setenv(SHMEM_HEAP_TYPE,
best_component->memheap_version.mca_component_name, 1);
mca_memheap = *best_module;
MEMHEAP_VERBOSE(10, MEMHEAP_VERBOSE(10,
"SELECTED %s component %s", "SELECTED %s component %s",
max_priority_component->memheap_version.mca_type_name, max_priority_component->memheap_version.mca_component_name); best_component->memheap_version.mca_type_name,
best_component->memheap_version.mca_component_name);
setenv(SHMEM_HEAP_TYPE,
max_priority_component->memheap_version.mca_component_name,
1);
mca_memheap = *mca_memheap_base_module_initialized;
return OSHMEM_SUCCESS; return OSHMEM_SUCCESS;
} }

Просмотреть файл

@ -18,8 +18,7 @@
#include "memheap_buddy_component.h" #include "memheap_buddy_component.h"
static int mca_memheap_buddy_component_close(void); static int mca_memheap_buddy_component_close(void);
static mca_memheap_base_module_t* mca_memheap_buddy_component_init(memheap_context_t *, static int mca_memheap_buddy_component_query(mca_base_module_t **module, int *priority);
int *);
static int _basic_open(void); static int _basic_open(void);
@ -33,12 +32,13 @@ mca_memheap_base_component_t mca_memheap_buddy_component = {
.mca_open_component = _basic_open, .mca_open_component = _basic_open,
.mca_close_component = mca_memheap_buddy_component_close, .mca_close_component = mca_memheap_buddy_component_close,
.mca_query_component = mca_memheap_buddy_component_query,
}, },
.memheap_data = { .memheap_data = {
/* The component is checkpoint ready */ /* The component is checkpoint ready */
MCA_BASE_METADATA_PARAM_CHECKPOINT MCA_BASE_METADATA_PARAM_CHECKPOINT
}, },
.memheap_init = mca_memheap_buddy_component_init, .memheap_init = mca_memheap_buddy_module_init
}; };
/* Open component */ /* Open component */
@ -47,19 +47,13 @@ static int _basic_open(void)
return OSHMEM_SUCCESS; return OSHMEM_SUCCESS;
} }
/* Initialize component */ /* query component */
mca_memheap_base_module_t* mca_memheap_buddy_component_init(memheap_context_t *context, static int
int *priority) mca_memheap_buddy_component_query(mca_base_module_t **module, int *priority)
{ {
int rc;
*priority = memheap_buddy.priority; *priority = memheap_buddy.priority;
rc = mca_memheap_buddy_module_init(context); *module = (mca_base_module_t *)&memheap_buddy.super;
if (OSHMEM_SUCCESS != rc) { return OSHMEM_SUCCESS;
return NULL ;
}
return &(memheap_buddy.super);
} }
/* /*

Просмотреть файл

@ -35,8 +35,7 @@ typedef struct memheap_context
/** /**
* Component initialize * Component initialize
*/ */
typedef struct mca_memheap_base_module_t* (*mca_memheap_base_component_init_fn_t)(memheap_context_t *, typedef int (*mca_memheap_base_component_init_fn_t)(memheap_context_t *);
int *priority);
/* /*
* Symmetric heap allocation. Malloc like interface * Symmetric heap allocation. Malloc like interface

Просмотреть файл

@ -18,8 +18,8 @@
#include "memheap_ptmalloc_component.h" #include "memheap_ptmalloc_component.h"
static int mca_memheap_ptmalloc_component_close(void); static int mca_memheap_ptmalloc_component_close(void);
static mca_memheap_base_module_t* mca_memheap_ptmalloc_component_init(memheap_context_t *, static int mca_memheap_ptmalloc_component_query(mca_base_module_t **module,
int *); int *priority);
static int _basic_open(void); static int _basic_open(void);
@ -33,12 +33,13 @@ mca_memheap_base_component_t mca_memheap_ptmalloc_component = {
.mca_open_component = _basic_open, .mca_open_component = _basic_open,
.mca_close_component = mca_memheap_ptmalloc_component_close, .mca_close_component = mca_memheap_ptmalloc_component_close,
.mca_query_component = mca_memheap_ptmalloc_component_query,
}, },
.memheap_data = { .memheap_data = {
/* The component is checkpoint ready */ /* The component is checkpoint ready */
MCA_BASE_METADATA_PARAM_CHECKPOINT MCA_BASE_METADATA_PARAM_CHECKPOINT
}, },
.memheap_init = mca_memheap_ptmalloc_component_init, .memheap_init = mca_memheap_ptmalloc_module_init,
}; };
/* Open component */ /* Open component */
@ -47,19 +48,13 @@ static int _basic_open(void)
return OSHMEM_SUCCESS; return OSHMEM_SUCCESS;
} }
/* Initialize component */ /* query component */
mca_memheap_base_module_t* mca_memheap_ptmalloc_component_init(memheap_context_t *context, static int
int *priority) mca_memheap_ptmalloc_component_query(mca_base_module_t **module, int *priority)
{ {
int rc;
*priority = memheap_ptmalloc.priority; *priority = memheap_ptmalloc.priority;
rc = mca_memheap_ptmalloc_module_init(context); *module = (mca_base_module_t *)&memheap_ptmalloc.super;
if (OSHMEM_SUCCESS != rc) { return OSHMEM_SUCCESS;
return NULL ;
}
return &(memheap_ptmalloc.super);
} }
/* /*