2010-12-27 21:32:34 +00:00
|
|
|
/**
|
2011-05-16 14:43:11 +00:00
|
|
|
Copyright (c) 2011 Mellanox Technologies. All rights reserved.
|
2010-12-27 21:32:34 +00:00
|
|
|
$COPYRIGHT$
|
|
|
|
|
|
|
|
Additional copyrights may follow
|
|
|
|
|
|
|
|
$HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "ompi_config.h"
|
|
|
|
|
|
|
|
#include <fca_api.h>
|
2012-11-02 17:30:00 +00:00
|
|
|
#include <config/fca_parse_specfile.h>
|
2010-12-27 21:32:34 +00:00
|
|
|
|
2010-12-28 07:11:46 +00:00
|
|
|
#ifndef FCA_API
|
|
|
|
#define OMPI_FCA_VERSION 12
|
|
|
|
#else
|
|
|
|
#define OMPI_FCA_VERSION FCA_API
|
|
|
|
#endif
|
|
|
|
|
2010-12-27 21:32:34 +00:00
|
|
|
/*
|
|
|
|
* FCA API compatibility layer.
|
|
|
|
* MPI build must define an FCA version macro.
|
|
|
|
*/
|
|
|
|
|
2010-12-28 07:11:46 +00:00
|
|
|
#define OMPI_FCA_BARRIER 1
|
|
|
|
#define OMPI_FCA_BCAST 1
|
|
|
|
#define OMPI_FCA_REDUCE 1
|
|
|
|
#define OMPI_FCA_ALLREDUCE 1
|
|
|
|
|
|
|
|
#define OMPI_FCA_REDUCE_SCATTER 0
|
|
|
|
#define OMPI_FCA_GATHER 0
|
|
|
|
#define OMPI_FCA_GATHERV 0
|
|
|
|
#define OMPI_FCA_ALLTOALL 0
|
|
|
|
#define OMPI_FCA_ALLTOALLV 0
|
|
|
|
#define OMPI_FCA_ALLTOALLW 0
|
|
|
|
|
|
|
|
|
|
|
|
#if OMPI_FCA_VERSION == 12
|
|
|
|
|
|
|
|
#define OMPI_FCA_ALLGATHER 0
|
2010-12-27 21:32:34 +00:00
|
|
|
|
2011-02-21 14:08:24 +00:00
|
|
|
#define FCA_API_ABI_MAJOR 1
|
|
|
|
#define FCA_API_ABI_MINOR 2
|
|
|
|
#define FCA_MAJOR_BIT 24ul
|
|
|
|
#define FCA_MINOR_BIT 16ul
|
|
|
|
#define EUSEMPI 287
|
2010-12-27 21:32:34 +00:00
|
|
|
|
|
|
|
static inline void mca_coll_fca_get_bcast_root(int root_rank, int *local_ranks,
|
|
|
|
int num_local_ranks,
|
|
|
|
fca_bcast_spec_t *spec)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < num_local_ranks; ++i) {
|
|
|
|
if (local_ranks[i] == root_rank) {
|
|
|
|
spec->root_indx = i;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
spec->root_indx = -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void mca_coll_fca_get_reduce_root(int root_rank, int my_rank,
|
|
|
|
fca_reduce_spec_t *spec)
|
|
|
|
{
|
|
|
|
spec->is_root = root_rank == my_rank;
|
|
|
|
}
|
|
|
|
|
2013-01-31 11:14:27 +00:00
|
|
|
#elif OMPI_FCA_VERSION >= 20
|
2010-12-28 07:11:46 +00:00
|
|
|
|
|
|
|
#define OMPI_FCA_ALLGATHER 1
|
2012-03-20 10:00:52 +00:00
|
|
|
#define OMPI_FCA_ALLGATHERV 1
|
2011-02-21 14:08:24 +00:00
|
|
|
#define OMPI_FCA_PROGRESS 1
|
2010-12-27 21:32:34 +00:00
|
|
|
|
2012-11-02 17:30:00 +00:00
|
|
|
static inline int mca_coll_fca_comm_init(fca_t *fca_context, int rank, int comm_size,
|
2010-12-27 21:32:34 +00:00
|
|
|
int local_proc_idx, int num_local_procs,
|
|
|
|
fca_comm_desc_t *comm_desc,
|
2013-01-31 11:14:27 +00:00
|
|
|
fca_comm_t **fca_comm
|
|
|
|
#if OMPI_FCA_VERSION >= 30
|
2013-10-22 17:05:55 +00:00
|
|
|
, void *comm_init_data
|
2013-01-31 11:14:27 +00:00
|
|
|
#endif
|
|
|
|
)
|
2010-12-27 21:32:34 +00:00
|
|
|
{
|
|
|
|
fca_comm_init_spec_t spec;
|
|
|
|
|
|
|
|
spec.rank = rank;
|
|
|
|
spec.size = comm_size;
|
|
|
|
spec.desc = *comm_desc;
|
|
|
|
spec.proc_idx = local_proc_idx;
|
|
|
|
spec.num_procs = num_local_procs;
|
2013-01-31 11:14:27 +00:00
|
|
|
#if OMPI_FCA_VERSION >= 30
|
|
|
|
spec.comm_init_data = comm_init_data;
|
|
|
|
#endif
|
2012-11-02 17:30:00 +00:00
|
|
|
return fca_comm_init(fca_context, &spec, fca_comm);
|
2010-12-27 21:32:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void mca_coll_fca_get_bcast_root(int root_rank, int *local_ranks,
|
|
|
|
int num_local_ranks,
|
|
|
|
fca_bcast_spec_t *spec)
|
|
|
|
{
|
|
|
|
spec->root = root_rank;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void mca_coll_fca_get_reduce_root(int root_rank, int my_rank,
|
|
|
|
fca_reduce_spec_t *spec)
|
|
|
|
{
|
|
|
|
spec->root = root_rank;
|
|
|
|
}
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
2011-02-21 14:08:24 +00:00
|
|
|
#error "FCA API version is unsupported"
|
2010-12-27 21:32:34 +00:00
|
|
|
|
|
|
|
#endif
|