Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
b1bcc881d2f9f37ece6ed98e4a581f7fe9c6844f
[simgrid.git] / src / smpi / colls / allgather-GB.cpp
1 /* Copyright (c) 2013-2014. The SimGrid Team.
2  * All rights reserved.                                                     */
3
4 /* This program is free software; you can redistribute it and/or modify it
5  * under the terms of the license (GNU LGPL) which comes with this package. */
6
7 #include "colls_private.h"
8
9 // Allgather - gather/bcast algorithm
10 int smpi_coll_tuned_allgather_GB(void *send_buff, int send_count,
11                                  MPI_Datatype send_type, void *recv_buff,
12                                  int recv_count, MPI_Datatype recv_type,
13                                  MPI_Comm comm)
14 {
15   int num_procs;
16   num_procs = smpi_comm_size(comm);
17   mpi_coll_gather_fun(send_buff, send_count, send_type, recv_buff, recv_count, recv_type,
18              0, comm);
19   mpi_coll_bcast_fun(recv_buff, (recv_count * num_procs), recv_type, 0, comm);
20
21   return MPI_SUCCESS;
22 }