forked from ESMCI/mpi-serial
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprobe.c
88 lines (63 loc) · 1.74 KB
/
probe.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
//probe.c
#include "mpiP.h"
static int mpi_match_send(void *r, void *tag)
{
return( *((int *)tag) == MPI_ANY_TAG ||
*((int *)tag) == ((Req *)r)->tag );
}
FC_FUNC(mpi_iprobe, MPI_IPROBE)(int * source, int * tag, int * comm,
int * flag, int *status, int * ierr)
{
*ierr = MPI_Iprobe(*source, *tag, *comm, flag, mpi_c_status(status));
}
/* Iprobe
* Search for existing message, return status about it
*/
int MPI_Iprobe(int source, int tag, MPI_Comm comm, int *flag,
MPI_Status *status)
{
pListitem match;
Comm *mycomm;
Req *sreq;
mycomm=mpi_handle_to_ptr(comm); /* mycomm=(Comm *)comm; */
#ifdef INFO
fflush(stdout);
fprintf(stderr,"MPI_IProbev: Comm=%d tag=%d count=%d type=%d\n",
mycomm->num,tag,count,datatype);
#endif
if (source!=0 && source!=MPI_ANY_SOURCE)
{
fprintf(stderr,"MPI_Irecv: bad source %d\n",source);
abort();
}
match=AP_list_search_func(mycomm->sendlist,mpi_match_send,&tag);
*flag= (match==NULL ? 0:1 );
if (*flag)
{
sreq=(Req *)AP_listitem_data(match);
if (status!=MPI_STATUS_IGNORE)
{
status->MPI_SOURCE=0 ;
status->MPI_TAG= sreq->tag;
}
}
return(MPI_SUCCESS);
}
//probe: wait for message, and return status
// (either message will immediately be available, or deadlock.
FC_FUNC(mpi_probe,MPI_PROBE)(int *source, int *tag, int *comm, int *status,
int *ierr)
{
*ierr=MPI_Probe(*source,*tag,*comm,mpi_c_status(status));
}
int MPI_Probe(int source, int tag, MPI_Comm comm, MPI_Status *status)
{
int flag;
MPI_Iprobe(source,tag,comm,&flag,status);
if (!flag)
{
fprintf(stderr,"MPI_Probe: no existing match, deadlock\n");
abort();
}
return(MPI_SUCCESS);
}