ompi/crcp: fix logic issue after component selection
CID 70630 Dereference before null check Cleaned up useless goto statements and deleted NULL check. If mca_base_select returns success than best_module and best_component will always be non-NULL. Signed-off-by: Nathan Hjelm <hjelmn@lanl.gov>
Этот коммит содержится в:
родитель
bc105afb10
Коммит
d21bd24126
@ -1,3 +1,4 @@
|
|||||||
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2004-2010 The Trustees of Indiana University.
|
* Copyright (c) 2004-2010 The Trustees of Indiana University.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
@ -7,6 +8,8 @@
|
|||||||
* University of Stuttgart. All rights reserved.
|
* University of Stuttgart. All rights reserved.
|
||||||
* Copyright (c) 2004-2005 The Regents of the University of California.
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2015 Los Alamos National Security, LLC. All rights
|
||||||
|
* reserved.
|
||||||
* $COPYRIGHT$
|
* $COPYRIGHT$
|
||||||
*
|
*
|
||||||
* Additional copyrights may follow
|
* Additional copyrights may follow
|
||||||
@ -117,7 +120,7 @@ static ompi_crcp_base_module_t none_module = {
|
|||||||
|
|
||||||
int ompi_crcp_base_select(void)
|
int ompi_crcp_base_select(void)
|
||||||
{
|
{
|
||||||
int ret, exit_status = OMPI_SUCCESS;
|
int ret;
|
||||||
ompi_crcp_base_component_t *best_component = NULL;
|
ompi_crcp_base_component_t *best_component = NULL;
|
||||||
ompi_crcp_base_module_t *best_module = NULL;
|
ompi_crcp_base_module_t *best_module = NULL;
|
||||||
const char *include_list = NULL;
|
const char *include_list = NULL;
|
||||||
@ -148,11 +151,10 @@ int ompi_crcp_base_select(void)
|
|||||||
best_module = &none_module;
|
best_module = &none_module;
|
||||||
/* JJH: Todo: Check if none is in the list */
|
/* JJH: Todo: Check if none is in the list */
|
||||||
/* Close all components since none will be used */
|
/* Close all components since none will be used */
|
||||||
mca_base_components_close(0, /* Pass 0 to keep this from closing the output handle */
|
mca_base_components_close(ompi_crcp_base_framework.framework_output,
|
||||||
&ompi_crcp_base_framework.framework_components,
|
&ompi_crcp_base_framework.framework_components,
|
||||||
NULL);
|
NULL);
|
||||||
goto skip_select;
|
} else
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Select the best component
|
* Select the best component
|
||||||
@ -162,24 +164,17 @@ int ompi_crcp_base_select(void)
|
|||||||
(mca_base_module_t **) &best_module,
|
(mca_base_module_t **) &best_module,
|
||||||
(mca_base_component_t **) &best_component) ) {
|
(mca_base_component_t **) &best_component) ) {
|
||||||
/* This will only happen if no component was selected */
|
/* This will only happen if no component was selected */
|
||||||
exit_status = OMPI_ERROR;
|
return OMPI_ERROR;
|
||||||
goto cleanup;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
skip_select:
|
|
||||||
/* Save the winner */
|
/* Save the winner */
|
||||||
ompi_crcp_base_selected_component = *best_component;
|
ompi_crcp_base_selected_component = *best_component;
|
||||||
ompi_crcp = *best_module;
|
ompi_crcp = *best_module;
|
||||||
|
|
||||||
/* Initialize the winner */
|
/* Initialize the winner */
|
||||||
if (NULL != best_module) {
|
if (OPAL_SUCCESS != (ret = ompi_crcp.crcp_init()) ) {
|
||||||
if (OPAL_SUCCESS != (ret = ompi_crcp.crcp_init()) ) {
|
return ret;
|
||||||
exit_status = ret;
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cleanup:
|
return OMPI_SUCCESS;
|
||||||
|
|
||||||
return exit_status;
|
|
||||||
}
|
}
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user