2011-08-25 20:08:17 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004-2005 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.
|
2015-06-23 20:59:57 -07:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2011-08-25 20:08:17 +00:00
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2016-07-20 14:46:44 -05:00
|
|
|
* Copyright (c) 2008-2016 University of Houston. All rights reserved.
|
2015-09-03 10:33:45 +09:00
|
|
|
* Copyright (c) 2015 Research Organization for Information Science
|
|
|
|
* and Technology (RIST). All rights reserved.
|
2011-08-25 20:08:17 +00:00
|
|
|
* $COPYRIGHT$
|
2015-06-23 20:59:57 -07:00
|
|
|
*
|
2011-08-25 20:08:17 +00:00
|
|
|
* Additional copyrights may follow
|
2015-06-23 20:59:57 -07:00
|
|
|
*
|
2011-08-25 20:08:17 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MCA_FCOLL_TWO_PHASE_EXPORT_H
|
|
|
|
#define MCA_FCOLL_TWO_PHASE_EXPORT_H
|
|
|
|
|
|
|
|
#include "ompi_config.h"
|
|
|
|
|
|
|
|
#include "mpi.h"
|
2015-03-05 20:50:44 -07:00
|
|
|
#include "ompi/mca/mca.h"
|
2011-08-25 20:08:17 +00:00
|
|
|
#include "ompi/mca/fcoll/fcoll.h"
|
|
|
|
#include "ompi/mca/fcoll/base/base.h"
|
2016-07-20 14:46:44 -05:00
|
|
|
#include "ompi/mca/common/ompio/common_ompio.h"
|
2011-08-25 20:08:17 +00:00
|
|
|
|
|
|
|
BEGIN_C_DECLS
|
|
|
|
|
|
|
|
/* Globally exported variables */
|
|
|
|
|
|
|
|
extern int mca_fcoll_two_phase_priority;
|
|
|
|
|
|
|
|
OMPI_MODULE_DECLSPEC extern mca_fcoll_base_component_2_0_0_t mca_fcoll_two_phase_component;
|
|
|
|
|
|
|
|
/* API functions */
|
|
|
|
|
|
|
|
int mca_fcoll_two_phase_component_init_query(bool enable_progress_threads,
|
|
|
|
bool enable_mpi_threads);
|
|
|
|
struct mca_fcoll_base_module_1_0_0_t *
|
|
|
|
mca_fcoll_two_phase_component_file_query (mca_io_ompio_file_t *fh, int *priority);
|
|
|
|
|
|
|
|
int mca_fcoll_two_phase_component_file_unquery (mca_io_ompio_file_t *file);
|
|
|
|
|
|
|
|
int mca_fcoll_two_phase_module_init (mca_io_ompio_file_t *file);
|
|
|
|
int mca_fcoll_two_phase_module_finalize (mca_io_ompio_file_t *file);
|
|
|
|
|
2015-06-23 20:59:57 -07:00
|
|
|
int mca_fcoll_two_phase_file_read_all (mca_io_ompio_file_t *fh,
|
|
|
|
void *buf,
|
2011-08-25 20:08:17 +00:00
|
|
|
int count,
|
2015-06-23 20:59:57 -07:00
|
|
|
struct ompi_datatype_t *datatype,
|
2011-08-25 20:08:17 +00:00
|
|
|
ompi_status_public_t * status);
|
|
|
|
|
|
|
|
|
2015-06-23 20:59:57 -07:00
|
|
|
int mca_fcoll_two_phase_file_write_all (mca_io_ompio_file_t *fh,
|
2015-09-03 10:33:45 +09:00
|
|
|
const void *buf,
|
2011-08-25 20:08:17 +00:00
|
|
|
int count,
|
2015-06-23 20:59:57 -07:00
|
|
|
struct ompi_datatype_t *datatype,
|
2011-08-25 20:08:17 +00:00
|
|
|
ompi_status_public_t * status);
|
|
|
|
|
|
|
|
|
2012-07-31 04:37:04 +00:00
|
|
|
int mca_fcoll_two_phase_calc_aggregator (mca_io_ompio_file_t *fh,
|
2015-06-23 20:59:57 -07:00
|
|
|
OMPI_MPI_OFFSET_TYPE off,
|
2012-07-31 04:37:04 +00:00
|
|
|
OMPI_MPI_OFFSET_TYPE min_off,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *len,
|
|
|
|
OMPI_MPI_OFFSET_TYPE fd_size,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *fd_start,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *fd_end,
|
|
|
|
int striping_unit,
|
2015-06-23 20:59:57 -07:00
|
|
|
int num_aggregators,
|
2012-07-31 04:37:04 +00:00
|
|
|
int *aggregator_list);
|
|
|
|
|
|
|
|
int mca_fcoll_two_phase_calc_others_requests(mca_io_ompio_file_t *fh,
|
|
|
|
int count_my_req_procs,
|
|
|
|
int *count_my_req_per_proc,
|
|
|
|
mca_io_ompio_access_array_t *my_req,
|
|
|
|
int *count_others_req_procs_ptr,
|
|
|
|
mca_io_ompio_access_array_t **others_req_ptr);
|
|
|
|
|
|
|
|
int mca_fcoll_two_phase_calc_my_requests (mca_io_ompio_file_t *fh,
|
|
|
|
struct iovec *offset_len,
|
|
|
|
int contig_access_count,
|
|
|
|
OMPI_MPI_OFFSET_TYPE min_st_offset,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *fd_start,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *fd_end,
|
|
|
|
OMPI_MPI_OFFSET_TYPE fd_size,
|
|
|
|
int *count_my_req_procs_ptr,
|
|
|
|
int **count_my_req_per_proc_ptr,
|
|
|
|
mca_io_ompio_access_array_t **my_req_ptr,
|
2012-11-12 17:39:58 +00:00
|
|
|
size_t **buf_indices,
|
2012-07-31 04:37:04 +00:00
|
|
|
int striping_unit,
|
|
|
|
int num_aggregators,
|
|
|
|
int *aggregator_list);
|
|
|
|
|
|
|
|
int mca_fcoll_two_phase_domain_partition (mca_io_ompio_file_t *fh,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *start_offsets,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *end_offsets,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *min_st_offset_ptr,
|
|
|
|
OMPI_MPI_OFFSET_TYPE **fd_st_ptr,
|
|
|
|
OMPI_MPI_OFFSET_TYPE **fd_end_ptr,
|
|
|
|
int min_fd_size,
|
|
|
|
OMPI_MPI_OFFSET_TYPE *fd_size_ptr,
|
|
|
|
int striping_unit,
|
|
|
|
int nprocs_for_coll);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-08-25 20:08:17 +00:00
|
|
|
END_C_DECLS
|
|
|
|
|
|
|
|
#endif /* MCA_FCOLL_TWO_PHASE_EXPORT_H */
|