source:
CIVL/mods/dev.civl.com/examples/contracts/contractsMPI/simpleMpiAgree.c@
cb4d4f4
| Last change on this file since cb4d4f4 was aad342c, checked in by , 3 years ago | |
|---|---|
|
|
| File size: 375 bytes | |
| Line | |
|---|---|
| 1 | #include<mpi.h> |
| 2 | #include<assert.h> |
| 3 | |
| 4 | |
| 5 | #define comm MPI_COMM_WORLD |
| 6 | |
| 7 | /*@ |
| 8 | @ \mpi_collective(comm, P2P): |
| 9 | @ requires \mpi_valid(x, 1, MPI_INT); |
| 10 | @ ensures \mpi_agree(*x); |
| 11 | @*/ |
| 12 | int bcast(int * x) { |
| 13 | return 0; |
| 14 | } |
| 15 | |
| 16 | |
| 17 | /*@ |
| 18 | @ \mpi_collective(comm, P2P): |
| 19 | @ ensures \mpi_agree(\result); |
| 20 | @*/ |
| 21 | int target() { |
| 22 | int rank; |
| 23 | |
| 24 | $havoc(&rank); |
| 25 | bcast(&rank); |
| 26 | return rank; |
| 27 | } |
Note:
See TracBrowser
for help on using the repository browser.
