global-io.cpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2014-2018, Regents of the University of California,
4  * Arizona Board of Regents,
5  * Colorado State University,
6  * University Pierre & Marie Curie, Sorbonne University,
7  * Washington University in St. Louis,
8  * Beijing Institute of Technology,
9  * The University of Memphis.
10  *
11  * This file is part of NFD (Named Data Networking Forwarding Daemon).
12  * See AUTHORS.md for complete list of NFD authors and contributors.
13  *
14  * NFD is free software: you can redistribute it and/or modify it under the terms
15  * of the GNU General Public License as published by the Free Software Foundation,
16  * either version 3 of the License, or (at your option) any later version.
17  *
18  * NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19  * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20  * PURPOSE. See the GNU General Public License for more details.
21  *
22  * You should have received a copy of the GNU General Public License along with
23  * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24  */
25 
26 #include "global-io.hpp"
27 #include <boost/thread/tss.hpp>
28 
29 namespace nfd {
30 
31 namespace scheduler {
32 // defined in scheduler.cpp
33 void
35 } // namespace scheduler
36 
37 static boost::thread_specific_ptr<boost::asio::io_service> g_ioService;
38 static boost::asio::io_service* g_mainIoService = nullptr;
39 static boost::asio::io_service* g_ribIoService = nullptr;
40 
41 boost::asio::io_service&
43 {
44  if (g_ioService.get() == nullptr) {
45  g_ioService.reset(new boost::asio::io_service());
46  }
47  return *g_ioService;
48 }
49 
50 void
52 {
54  g_ioService.reset();
55 }
56 
57 void
58 setMainIoService(boost::asio::io_service* mainIo)
59 {
60  g_mainIoService = mainIo;
61 }
62 
63 void
64 setRibIoService(boost::asio::io_service* ribIo)
65 {
66  g_ribIoService = ribIo;
67 }
68 
69 boost::asio::io_service&
71 {
72  BOOST_ASSERT(g_mainIoService != nullptr);
73  return *g_mainIoService;
74 }
75 
76 boost::asio::io_service&
78 {
79  BOOST_ASSERT(g_ribIoService != nullptr);
80  return *g_ribIoService;
81 }
82 
83 void
84 runOnMainIoService(const std::function<void()>& f)
85 {
86  getMainIoService().post(f);
87 }
88 
89 void
90 runOnRibIoService(const std::function<void()>& f)
91 {
92  getRibIoService().post(f);
93 }
94 
95 } // namespace nfd
static boost::thread_specific_ptr< boost::asio::io_service > g_ioService
Definition: global-io.cpp:37
static boost::asio::io_service * g_ribIoService
Definition: global-io.cpp:39
void runOnRibIoService(const std::function< void()> &f)
run a function on the RIB io_service instance
Definition: global-io.cpp:90
void setMainIoService(boost::asio::io_service *mainIo)
Definition: global-io.cpp:58
void runOnMainIoService(const std::function< void()> &f)
run a function on the main io_service instance
Definition: global-io.cpp:84
boost::asio::io_service & getMainIoService()
Definition: global-io.cpp:70
void resetGlobalIoService()
Definition: global-io.cpp:51
boost::asio::io_service & getRibIoService()
Definition: global-io.cpp:77
Copyright (c) 2014-2015, Regents of the University of California, Arizona Board of Regents...
Definition: algorithm.hpp:32
void resetGlobalScheduler()
Definition: scheduler.cpp:53
static boost::asio::io_service * g_mainIoService
Definition: global-io.cpp:38
void setRibIoService(boost::asio::io_service *ribIo)
Definition: global-io.cpp:64
boost::asio::io_service & getGlobalIoService()
Definition: global-io.cpp:42