From 943c9b6f6f284bdedb362621ea85915bce67abae Mon Sep 17 00:00:00 2001 From: bosilca Date: Tue, 31 Jan 2017 21:47:36 -0500 Subject: [PATCH] Properly initialize tuned MCA parameters Picked from parts of PR #3497 that fix a problem with registering tuned MCA parameters. Original code passed stack variables to the MCA parameter registration framework - a no no. Signed-off-by: George Bosilca Signed-off-by: Howard Pritchard (cherry picked from commit 667ec2a1523aeb62251770d34a51abba609e88d0) --- ompi/mca/coll/tuned/coll_tuned_allgather_decision.c | 4 ++-- ompi/mca/coll/tuned/coll_tuned_allgatherv_decision.c | 4 ++-- ompi/mca/coll/tuned/coll_tuned_allreduce_decision.c | 4 ++-- ompi/mca/coll/tuned/coll_tuned_alltoall_decision.c | 4 ++-- ompi/mca/coll/tuned/coll_tuned_alltoallv_decision.c | 4 ++-- ompi/mca/coll/tuned/coll_tuned_bcast_decision.c | 4 ++-- ompi/mca/coll/tuned/coll_tuned_gather_decision.c | 5 ++--- ompi/mca/coll/tuned/coll_tuned_reduce_decision.c | 4 ++-- ompi/mca/coll/tuned/coll_tuned_reduce_scatter_decision.c | 4 ++-- ompi/mca/coll/tuned/coll_tuned_scatter_decision.c | 4 ++-- opal/mca/base/mca_base_var.h | 2 -- 11 files changed, 20 insertions(+), 23 deletions(-) diff --git a/ompi/mca/coll/tuned/coll_tuned_allgather_decision.c b/ompi/mca/coll/tuned/coll_tuned_allgather_decision.c index 21b4026ac12..240b6c03388 100644 --- a/ompi/mca/coll/tuned/coll_tuned_allgather_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_allgather_decision.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -69,7 +69,7 @@ ompi_coll_tuned_allgather_intra_check_forced_init(coll_tuned_force_algorithm_mca MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[ALLGATHER]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_allgather_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_allgatherv_decision.c b/ompi/mca/coll/tuned/coll_tuned_allgatherv_decision.c index 7d68498eb2c..e46dd8d4cd7 100644 --- a/ompi/mca/coll/tuned/coll_tuned_allgatherv_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_allgatherv_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -68,7 +68,7 @@ ompi_coll_tuned_allgatherv_intra_check_forced_init(coll_tuned_force_algorithm_mc MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[ALLGATHERV]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_allgatherv_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_allreduce_decision.c b/ompi/mca/coll/tuned/coll_tuned_allreduce_decision.c index 2fafe780058..1d49772d5c3 100644 --- a/ompi/mca/coll/tuned/coll_tuned_allreduce_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_allreduce_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -68,7 +68,7 @@ int ompi_coll_tuned_allreduce_intra_check_forced_init (coll_tuned_force_algorith MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[ALLREDUCE]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_allreduce_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_alltoall_decision.c b/ompi/mca/coll/tuned/coll_tuned_alltoall_decision.c index 7db956164f9..faf54b6f50b 100644 --- a/ompi/mca/coll/tuned/coll_tuned_alltoall_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_alltoall_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -67,7 +67,7 @@ int ompi_coll_tuned_alltoall_intra_check_forced_init (coll_tuned_force_algorithm MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[ALLTOALL]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_alltoall_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_alltoallv_decision.c b/ompi/mca/coll/tuned/coll_tuned_alltoallv_decision.c index 871aa1eceb4..a7cd332a647 100644 --- a/ompi/mca/coll/tuned/coll_tuned_alltoallv_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_alltoallv_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -61,7 +61,7 @@ int ompi_coll_tuned_alltoallv_intra_check_forced_init(coll_tuned_force_algorithm MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[ALLTOALLV]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_alltoallv_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_bcast_decision.c b/ompi/mca/coll/tuned/coll_tuned_bcast_decision.c index 81345b270fe..3bc0178c370 100644 --- a/ompi/mca/coll/tuned/coll_tuned_bcast_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_bcast_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -67,7 +67,7 @@ int ompi_coll_tuned_bcast_intra_check_forced_init (coll_tuned_force_algorithm_mc MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[BCAST]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_bcast_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_gather_decision.c b/ompi/mca/coll/tuned/coll_tuned_gather_decision.c index 09da5f1a070..e517ecd47ac 100644 --- a/ompi/mca/coll/tuned/coll_tuned_gather_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_gather_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -58,7 +58,6 @@ ompi_coll_tuned_gather_intra_check_forced_init(coll_tuned_force_algorithm_mca_pa int cnt; for( cnt = 0; NULL != gather_algorithms[cnt].string; cnt++ ); - ompi_coll_tuned_forced_max_algorithms[GATHER] = cnt; (void) mca_base_component_var_register(&mca_coll_tuned_component.super.collm_version, @@ -68,7 +67,7 @@ ompi_coll_tuned_gather_intra_check_forced_init(coll_tuned_force_algorithm_mca_pa MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[GATHER]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_gather_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_reduce_decision.c b/ompi/mca/coll/tuned/coll_tuned_reduce_decision.c index bae6ebef6f2..fff12e45de2 100644 --- a/ompi/mca/coll/tuned/coll_tuned_reduce_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_reduce_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -71,7 +71,7 @@ int ompi_coll_tuned_reduce_intra_check_forced_init (coll_tuned_force_algorithm_m MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[REDUCE]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_reduce_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_reduce_scatter_decision.c b/ompi/mca/coll/tuned/coll_tuned_reduce_scatter_decision.c index 33b31be1c43..01ed776a750 100644 --- a/ompi/mca/coll/tuned/coll_tuned_reduce_scatter_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_reduce_scatter_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -68,7 +68,7 @@ int ompi_coll_tuned_reduce_scatter_intra_check_forced_init (coll_tuned_force_alg MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[REDUCESCATTER]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_reduce_scatter_forced_algorithm = 0; diff --git a/ompi/mca/coll/tuned/coll_tuned_scatter_decision.c b/ompi/mca/coll/tuned/coll_tuned_scatter_decision.c index 6bfec329df3..fad61958a6f 100644 --- a/ompi/mca/coll/tuned/coll_tuned_scatter_decision.c +++ b/ompi/mca/coll/tuned/coll_tuned_scatter_decision.c @@ -1,6 +1,6 @@ /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* - * Copyright (c) 2004-2015 The University of Tennessee and The University + * Copyright (c) 2004-2017 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2015 Research Organization for Information Science @@ -66,7 +66,7 @@ ompi_coll_tuned_scatter_intra_check_forced_init(coll_tuned_force_algorithm_mca_p MCA_BASE_VAR_FLAG_DEFAULT_ONLY, OPAL_INFO_LVL_5, MCA_BASE_VAR_SCOPE_CONSTANT, - &cnt); + &ompi_coll_tuned_forced_max_algorithms[SCATTER]); /* MPI_T: This variable should eventually be bound to a communicator */ coll_tuned_scatter_forced_algorithm = 0; diff --git a/opal/mca/base/mca_base_var.h b/opal/mca/base/mca_base_var.h index 46b8a2ce760..e74f02bdd5b 100644 --- a/opal/mca/base/mca_base_var.h +++ b/opal/mca/base/mca_base_var.h @@ -496,8 +496,6 @@ OPAL_DECLSPEC int mca_base_var_deregister(int vari); * * @param[in] vari Index of variable * @param[in,out] value Pointer to copy the value to. Can be NULL. - * @param[in,out] value_size Size of memory pointed to by value. - * copied size will be returned in value_size. * @param[out] source Source of current value. Can be NULL. * @param[out] source_file Source file for the current value if * it was set from a file.