/* * Copyright (c) 2004-2005 The Trustees of Indiana University. * All rights reserved. * Copyright (c) 2004-2005 The Trustees of the University of Tennessee. * 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$ * * Additional copyrights may follow * * $HEADER$ */ /** @file */ #include "ompi_config.h" #include "ompi/include/constants.h" #include "coll_sm.h" /** * Shared memory allreduce. * * For the moment, all we're doing is a reduce to root==0 and then a * broadcast. It is possible that we'll do something better someday. */ int mca_coll_sm_allreduce_intra(void *sbuf, void *rbuf, int count, struct ompi_datatype_t *dtype, struct ompi_op_t *op, struct ompi_communicator_t *comm) { int ret; ret = mca_coll_sm_reduce_intra(sbuf, rbuf, count, dtype, op, 0, comm); return (ret == OMPI_SUCCESS) ? mca_coll_sm_bcast_intra(rbuf, count, dtype, 0, comm) : ret; }