source: ThirdParty/vmg/src/comm/mpi/has_request_vec.hpp

Candidate_v1.6.1
Last change on this file was 7faa5c, checked in by Frederik Heber <heber@…>, 8 years ago

Merge commit 'de061d9d851257a04e924d4472df4523d33bb08b' as 'ThirdParty/vmg'

  • Property mode set to 100644
File size: 1.9 KB
Line 
1/*
2 * vmg - a versatile multigrid solver
3 * Copyright (C) 2012 Institute for Numerical Simulation, University of Bonn
4 *
5 * vmg is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
9 *
10 * vmg is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18
19/**
20 * @file has_request_vec.hpp
21 * @author Julian Iseringhausen <isering@ins.uni-bonn.de>
22 * @date Mon Nov 21 13:27:22 2011
23 *
24 * @brief A convenience base class for classes using MPI_Requests.
25 *
26 */
27
28
29#ifndef HAS_REQUEST_VEC_HPP_
30#define HAS_REQUEST_VEC_HPP_
31
32#include <vector>
33
34#ifdef HAVE_MPI
35
36namespace VMG
37{
38
39class HasRequestVec
40{
41protected:
42
43MPI_Request& Request()
44{
45 request_vec.push_back(MPI_Request());
46 return request_vec.back();
47}
48
49void WaitAll()
50{
51 if (!request_vec.empty()) {
52#ifndef NDEBUG
53 int rval = MPI_Waitall(static_cast<int>(request_vec.size()), &request_vec.front(), MPI_STATUSES_IGNORE);
54 assert(rval == MPI_SUCCESS);
55#else
56 MPI_Waitall(static_cast<int>(request_vec.size()), &request_vec.front(), MPI_STATUSES_IGNORE);
57#endif
58 request_vec.clear();
59 }
60}
61
62int TestAll()
63{
64 int flag = 1;
65 if (!request_vec.empty())
66 MPI_Testall(request_vec.size(), &request_vec.front(), &flag, MPI_STATUSES_IGNORE);
67 return flag;
68}
69
70size_t RequestsPending()
71{
72 return request_vec.size();
73}
74
75private:
76 std::vector<MPI_Request> request_vec;
77};
78
79}
80
81#endif /* HAVE_MPI */
82
83#endif /* HAS_REQUEST_VEC_HPP_ */
Note: See TracBrowser for help on using the repository browser.