This source file includes following definitions.
- MPI_Comm_create
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21 #include "ompi_config.h"
22 #include <stdio.h>
23
24 #include "ompi/mpi/c/bindings.h"
25 #include "ompi/runtime/params.h"
26 #include "ompi/communicator/communicator.h"
27 #include "ompi/errhandler/errhandler.h"
28 #include "ompi/memchecker.h"
29
30 #if OMPI_BUILD_MPI_PROFILING
31 #if OPAL_HAVE_WEAK_SYMBOLS
32 #pragma weak MPI_Comm_create = PMPI_Comm_create
33 #endif
34 #define MPI_Comm_create PMPI_Comm_create
35 #endif
36
37 static const char FUNC_NAME[] = "MPI_Comm_create";
38
39
40 int MPI_Comm_create(MPI_Comm comm, MPI_Group group, MPI_Comm *newcomm) {
41
42 int rc;
43
44 MEMCHECKER(
45 memchecker_comm(comm);
46 );
47
48 if ( MPI_PARAM_CHECK ) {
49 OMPI_ERR_INIT_FINALIZE(FUNC_NAME);
50
51 if (ompi_comm_invalid (comm))
52 return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_COMM,
53 FUNC_NAME);
54
55 if ( MPI_GROUP_NULL == group || NULL == group )
56 return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_GROUP,
57 FUNC_NAME);
58
59 if ( NULL == newcomm )
60 return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG,
61 FUNC_NAME);
62 }
63
64 OPAL_CR_ENTER_LIBRARY();
65
66 rc = ompi_comm_create ( (ompi_communicator_t*)comm, (ompi_group_t*)group,
67 (ompi_communicator_t**)newcomm );
68 OMPI_ERRHANDLER_RETURN ( rc, comm, rc, FUNC_NAME);
69 }