1
1

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>
Этот коммит содержится в:
Nathan Hjelm 2015-05-26 11:48:40 -06:00
родитель 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;
} }