blob: 177045f407f65e1cf0d9ba4a0b9bb1530b7b5fac [file] [log] [blame]
Alexander Afanasyev920af2f2014-01-25 22:56:11 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Alexander Afanasyev5d57f972015-02-11 21:04:29 -08003 * Copyright (c) 2014-2015, 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.
Alexander Afanasyev9bcbc7c2014-04-06 19:37:37 -070010 *
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/>.
Junxiao Shi27533da2014-12-15 10:56:20 -070024 */
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080025
26#include "scheduler.hpp"
Junxiao Shi98e29f42014-03-31 10:27:26 -070027#include "global-io.hpp"
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080028
Alexander Afanasyev5d57f972015-02-11 21:04:29 -080029#include <boost/thread/tss.hpp>
30
Alexander Afanasyev18bbf812014-01-29 01:40:23 -080031namespace nfd {
Junxiao Shic041ca32014-02-25 20:01:15 -070032namespace scheduler {
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080033
Alexander Afanasyev5d57f972015-02-11 21:04:29 -080034static boost::thread_specific_ptr<Scheduler> g_scheduler;
Junxiao Shic041ca32014-02-25 20:01:15 -070035
Alexander Afanasyev5d57f972015-02-11 21:04:29 -080036Scheduler&
Junxiao Shic041ca32014-02-25 20:01:15 -070037getGlobalScheduler()
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080038{
Alexander Afanasyev5d57f972015-02-11 21:04:29 -080039 if (g_scheduler.get() == nullptr) {
40 g_scheduler.reset(new Scheduler(getGlobalIoService()));
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080041 }
Alexander Afanasyev5d57f972015-02-11 21:04:29 -080042
Junxiao Shic041ca32014-02-25 20:01:15 -070043 return *g_scheduler;
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080044}
45
Junxiao Shi98e29f42014-03-31 10:27:26 -070046EventId
47schedule(const time::nanoseconds& after, const Scheduler::Event& event)
48{
49 return getGlobalScheduler().scheduleEvent(after, event);
50}
51
52void
53cancel(const EventId& eventId)
54{
55 getGlobalScheduler().cancelEvent(eventId);
56}
57
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080058void
Junxiao Shic041ca32014-02-25 20:01:15 -070059resetGlobalScheduler()
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080060{
Junxiao Shic041ca32014-02-25 20:01:15 -070061 g_scheduler.reset();
Alexander Afanasyev920af2f2014-01-25 22:56:11 -080062}
63
Junxiao Shi27533da2014-12-15 10:56:20 -070064ScopedEventId::ScopedEventId()
65{
66}
67
68ScopedEventId::ScopedEventId(const EventId& event)
69 : m_event(event)
70{
71}
72
73ScopedEventId::ScopedEventId(ScopedEventId&& other)
74 : m_event(other.m_event)
75{
76 other.release();
77}
78
79ScopedEventId&
80ScopedEventId::operator=(const EventId& event)
81{
82 if (m_event != event) {
83 scheduler::cancel(m_event);
84 m_event = event;
85 }
86 return *this;
87}
88
89ScopedEventId::~ScopedEventId()
90{
91 scheduler::cancel(m_event);
92}
93
94void
95ScopedEventId::cancel()
96{
97 scheduler::cancel(m_event);
98}
99
100void
101ScopedEventId::release()
102{
103 m_event.reset();
104}
105
Junxiao Shic041ca32014-02-25 20:01:15 -0700106} // namespace scheduler
Alexander Afanasyev18bbf812014-01-29 01:40:23 -0800107} // namespace nfd