1 // RUN: %clang_cc1 -analyze -analyzer-checker=optin.mpi.MPI-Checker -analyzer-output=text -verify %s 2 3 // MPI-Checker test file to test note diagnostics. 4 5 #include "MPIMock.h" 6 7 void doubleNonblocking() { 8 double buf = 0; 9 MPI_Request sendReq; 10 MPI_Isend(&buf, 1, MPI_DOUBLE, 0, 0, MPI_COMM_WORLD, &sendReq); // expected-note{{Request is previously used by nonblocking call here.}} 11 MPI_Irecv(&buf, 1, MPI_DOUBLE, 0, 0, MPI_COMM_WORLD, &sendReq); // expected-warning{{Double nonblocking on request 'sendReq'.}} expected-note{{Double nonblocking on request 'sendReq'.}} 12 MPI_Wait(&sendReq, MPI_STATUS_IGNORE); 13 } 14 15 void missingWait() { 16 double buf = 0; 17 MPI_Request sendReq; 18 MPI_Ireduce(MPI_IN_PLACE, &buf, 1, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD, &sendReq); // expected-note{{Request is previously used by nonblocking call here.}} 19 } // expected-warning{{Request 'sendReq' has no matching wait.}} expected-note{{Request 'sendReq' has no matching wait.}} 20 21 // If more than 2 nonblocking calls are using a request in a sequence, they all 22 // point to the first call as the 'previous' call. This is because the 23 // BugReporterVisitor only checks for differences in state or existence of an 24 // entity. 25 void tripleNonblocking() { 26 double buf = 0; 27 MPI_Request sendReq; 28 MPI_Isend(&buf, 1, MPI_DOUBLE, 0, 0, MPI_COMM_WORLD, &sendReq); // expected-note 2{{Request is previously used by nonblocking call here.}} 29 MPI_Irecv(&buf, 1, MPI_DOUBLE, 0, 0, MPI_COMM_WORLD, &sendReq); // expected-warning{{Double nonblocking on request 'sendReq'.}} expected-note{{Double nonblocking on request 'sendReq'.}} 30 31 MPI_Isend(&buf, 1, MPI_DOUBLE, 0, 0, MPI_COMM_WORLD, &sendReq); // expected-warning{{Double nonblocking on request 'sendReq'.}} expected-note{{Double nonblocking on request 'sendReq'.}} 32 33 MPI_Wait(&sendReq, MPI_STATUS_IGNORE); 34 } 35