450ccd439b
adjust the fcoll selection table to achieve the following: - two_phase should not advertise itself on lustre file systems - two_phase should advertise itself on sequential file systems (stripe_size == 0 ) - priority for dynamic, static and individual is reduced. This will lead to two_phase being selected in scenarios where two or more components indicate willingness to run. Signed-off-by: Edgar Gabriel <gabriel@cs.uh.edu>
91 строка
2.5 KiB
C
91 строка
2.5 KiB
C
/*
|
|
* Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana
|
|
* University Research and Technology
|
|
* Corporation. All rights reserved.
|
|
* Copyright (c) 2004-2006 The University of Tennessee and The University
|
|
* of Tennessee Research Foundation. All rights
|
|
* reserved.
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
* University of Stuttgart. All rights reserved.
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
* All rights reserved.
|
|
* Copyright (c) 2008-2015 University of Houston. All rights reserved.
|
|
* $COPYRIGHT$
|
|
*
|
|
* Additional copyrights may follow
|
|
*
|
|
* $HEADER$
|
|
*/
|
|
|
|
#include "ompi_config.h"
|
|
#include "fcoll_dynamic.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "mpi.h"
|
|
#include "ompi/mca/fcoll/fcoll.h"
|
|
#include "ompi/mca/fcoll/base/base.h"
|
|
|
|
|
|
/*
|
|
* *******************************************************************
|
|
* ************************ actions structure ************************
|
|
* *******************************************************************
|
|
*/
|
|
static mca_fcoll_base_module_1_0_0_t dynamic = {
|
|
mca_fcoll_dynamic_module_init,
|
|
mca_fcoll_dynamic_module_finalize,
|
|
mca_fcoll_dynamic_file_read_all,
|
|
NULL, /* iread_all */
|
|
mca_fcoll_dynamic_file_write_all,
|
|
NULL, /*iwrite_all */
|
|
NULL, /* progress */
|
|
NULL /* request_free */
|
|
};
|
|
|
|
int
|
|
mca_fcoll_dynamic_component_init_query(bool enable_progress_threads,
|
|
bool enable_mpi_threads)
|
|
{
|
|
/* Nothing to do */
|
|
|
|
return OMPI_SUCCESS;
|
|
}
|
|
|
|
mca_fcoll_base_module_1_0_0_t *
|
|
mca_fcoll_dynamic_component_file_query (mca_io_ompio_file_t *fh, int *priority)
|
|
{
|
|
*priority = mca_fcoll_dynamic_priority;
|
|
if (0 >= mca_fcoll_dynamic_priority) {
|
|
return NULL;
|
|
}
|
|
|
|
if (mca_fcoll_base_query_table (fh, "dynamic")) {
|
|
if (*priority < 30) {
|
|
*priority = 30;
|
|
}
|
|
}
|
|
|
|
return &dynamic;
|
|
}
|
|
|
|
int mca_fcoll_dynamic_component_file_unquery (mca_io_ompio_file_t *file)
|
|
{
|
|
/* This function might be needed for some purposes later. for now it
|
|
* does not have anything to do since there are no steps which need
|
|
* to be undone if this module is not selected */
|
|
|
|
return OMPI_SUCCESS;
|
|
}
|
|
|
|
int mca_fcoll_dynamic_module_init (mca_io_ompio_file_t *file)
|
|
{
|
|
return OMPI_SUCCESS;
|
|
}
|
|
|
|
|
|
int mca_fcoll_dynamic_module_finalize (mca_io_ompio_file_t *file)
|
|
{
|
|
return OMPI_SUCCESS;
|
|
}
|