A Discrete-Event Network Simulator
API
main-test-sync.cc
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2008 University of Washington
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  */
18 
19 #include "ns3/command-line.h"
20 #include "ns3/simulator.h"
21 #include "ns3/realtime-simulator-impl.h"
22 #include "ns3/nstime.h"
23 #include "ns3/log.h"
24 #include "ns3/system-thread.h"
25 #include "ns3/string.h"
26 #include "ns3/config.h"
27 #include "ns3/global-value.h"
28 #include "ns3/ptr.h"
29 
30 #include <chrono> // seconds, milliseconds
31 #include <thread> // sleep_for
32 
43 using namespace ns3;
44 
45 
46 NS_LOG_COMPONENT_DEFINE ("TestSync");
47 
48 namespace {
49 
51 bool gFirstRun = false;
52 
54 void
55 inserted_function (void)
56 {
57  NS_ASSERT (gFirstRun);
58  NS_LOG_UNCOND ("inserted_function() called at " <<
59  Simulator::Now ().GetSeconds () << " s");
60 }
61 
63 void
64 background_function (void)
65 {
66  NS_ASSERT (gFirstRun);
67  NS_LOG_UNCOND ("background_function() called at " <<
68  Simulator::Now ().GetSeconds () << " s");
69 }
70 
72 void
73 first_function (void)
74 {
75  NS_LOG_UNCOND ("first_function() called at " <<
76  Simulator::Now ().GetSeconds () << " s");
77  gFirstRun = true;
78 }
79 
81 class FakeNetDevice
82 {
83 public:
85  FakeNetDevice ();
87  void Doit3 (void);
88 };
89 
90 FakeNetDevice::FakeNetDevice ()
91 {
93 }
94 
95 void
96 FakeNetDevice::Doit3 (void)
97 {
99  std::this_thread::sleep_for (std::chrono::seconds (1));
100 
101  for (uint32_t i = 0; i < 10000; ++i)
102  {
103  //
104  // Exercise the realtime relative now path
105  //
107  std::this_thread::sleep_for (std::chrono::milliseconds (1));
108  }
109 }
110 
120 void
121 test (void)
122 {
123  GlobalValue::Bind ("SimulatorImplementationType",
124  StringValue ("ns3::RealtimeSimulatorImpl"));
125 
126  FakeNetDevice fnd;
127 
128  //
129  // Make sure ScheduleNow works when the system isn't running
130  //
131  Simulator::ScheduleWithContext (0xffffffff, Seconds (0.0), MakeEvent (&first_function));
132 
133  //
134  // drive the progression of m_currentTs at a ten millisecond rate from the main thread
135  //
136  for (double d = 0.; d < 14.999; d += 0.01)
137  {
138  Simulator::Schedule (Seconds (d), &background_function);
139  }
140 
141  Ptr<SystemThread> st3 = Create<SystemThread> (
142  MakeCallback (&FakeNetDevice::Doit3, &fnd));
143  st3->Start ();
144 
145  Simulator::Stop (Seconds (15.0));
146  Simulator::Run ();
147  st3->Join ();
149 }
150 
151 } // unnamed namespace
152 
153 
154 int
155 main (int argc, char *argv[])
156 {
157  CommandLine cmd (__FILE__);
158  cmd.Parse (argc, argv);
159 
160  while (true)
161  {
162  test ();
163  }
164 }
165 
static EventId Schedule(Time const &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
Definition: simulator.h:557
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:73
Hold variables of type string.
Definition: string.h:41
void Start(void)
Start a thread of execution, running the provided callback.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file...
Definition: assert.h:67
static void Run(void)
Run the simulation.
Definition: simulator.cc:172
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:205
cmd
Definition: second.py:35
#define NS_LOG_FUNCTION_NOARGS()
Output the name of the function.
static void Bind(std::string name, const AttributeValue &value)
Iterate over the set of GlobalValues until a matching name is found and then set its value with Globa...
Parse command-line arguments.
Definition: command-line.h:226
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
Definition: simulator.cc:136
static void ScheduleWithContext(uint32_t context, Time const &delay, FUNC f, Ts &&... args)
Schedule an event with the given context.
Definition: simulator.h:572
Every class exported by the ns3 library is enclosed in the ns3 namespace.
#define NS_LOG_UNCOND(msg)
Output the requested message unconditionally.
static Time Now(void)
Return the current simulation virtual time.
Definition: simulator.cc:195
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Definition: simulator.cc:180
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1278
void Join(void)
Suspend the caller until the thread of execution, running the provided callback, finishes.
Flag for events not associated with any particular context.
Definition: simulator.h:199
Callback< R, Ts... > MakeCallback(R(T::*memPtr)(Ts...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
Definition: callback.h:1642
EventImpl * MakeEvent(void(*f)(void))
Make an EventImpl from a function pointer taking varying numbers of arguments.
Definition: make-event.cc:34