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>
Этот коммит содержится в:
родитель
6d59b476de
Коммит
83c2ab76a5
@ -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);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user