This source file includes following definitions.
- MPI_Op_commutative
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
23 #include <stdio.h>
24
25 #include "ompi/mpi/c/bindings.h"
26 #include "ompi/runtime/params.h"
27 #include "ompi/communicator/communicator.h"
28 #include "ompi/errhandler/errhandler.h"
29 #include "ompi/op/op.h"
30
31 #if OMPI_BUILD_MPI_PROFILING
32 #if OPAL_HAVE_WEAK_SYMBOLS
33 #pragma weak MPI_Op_commutative = PMPI_Op_commutative
34 #endif
35 #define MPI_Op_commutative PMPI_Op_commutative
36 #endif
37
38 static const char FUNC_NAME[] = "MPI_Op_commutative";
39
40
41 int MPI_Op_commutative(MPI_Op op, int *commute)
42 {
43 OPAL_CR_NOOP_PROGRESS();
44
45
46
47 if (MPI_PARAM_CHECK) {
48 OMPI_ERR_INIT_FINALIZE(FUNC_NAME);
49 if (NULL == op || MPI_OP_NULL == op) {
50 return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_OP,
51 FUNC_NAME);
52 }
53 if (NULL == commute) {
54 return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_ARG,
55 FUNC_NAME);
56 }
57 }
58
59
60
61 *commute = ompi_op_is_commute(op);
62
63
64
65 return MPI_SUCCESS;
66 }