Contexts
data:image/s3,"s3://crabby-images/86ce8/86ce8ddf2dca3c04bf4cecf9db85c92f0b435379" alt=""
data:image/s3,"s3://crabby-images/10bc6/10bc6719745dab92d26f0ccdc98c9c0e4ea90d34" alt=""
data:image/s3,"s3://crabby-images/efa54/efa547446191284a42fe3bca909ef0b570bf4e31" alt=""
Up: Basic Concepts Next: Intra-Communicators Previous: Groups
A context is a property of communicators (defined next) that allows partitioning of the communication space. A message sent in one context cannot be received in another context. Furthermore, where permitted, collective operations are independent of pending point-to-point operations. Contexts are not explicit MPI objects; they appear only as part of the realization of communicators (below).
[] Advice
to implementors.
Distinct communicators in the same process have distinct contexts. A context is essentially a system-managed tag (or tags) needed to make a communicator safe for point-to-point and MPI-defined collective communication. Safety means that collective and point-to-point communication within one communicator do not interfere, and that communication over distinct communicators don't interfere.
A possible implementation for a context is as a supplemental tag attached to messages on send and matched on receive. Each intra-communicator stores the value of its two tags (one for point-to-point and one for collective communication). Communicator-generating functions use a collective communication to agree on a new group-wide unique context.
Analogously, in inter-communication (which is strictly point-to-point communication), two context tags are stored per communicator, one used by group A to send and group B to receive, and a second used by group B to send and for group A to receive.
Since contexts are not explicit objects, other
implementations are also possible.
( End of advice to implementors.)
data:image/s3,"s3://crabby-images/86ce8/86ce8ddf2dca3c04bf4cecf9db85c92f0b435379" alt=""
data:image/s3,"s3://crabby-images/10bc6/10bc6719745dab92d26f0ccdc98c9c0e4ea90d34" alt=""
data:image/s3,"s3://crabby-images/efa54/efa547446191284a42fe3bca909ef0b570bf4e31" alt=""
Up: Basic Concepts Next: Intra-Communicators Previous: Groups
Return to MPI Standard Index
Return to MPI home page