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 <unistd.h>
31 #include <sys/time.h>
32 
42 using namespace ns3;
43 
44 NS_LOG_COMPONENT_DEFINE ("TestSync");
45 
47 bool gFirstRun = false;
48 
50 void
52 {
54  NS_LOG_UNCOND ("inserted_function() called at " <<
55  Simulator::Now ().GetSeconds () << " s");
56 }
57 
59 void
61 {
63  NS_LOG_UNCOND ("background_function() called at " <<
64  Simulator::Now ().GetSeconds () << " s");
65 }
66 
68 void
70 {
71  NS_LOG_UNCOND ("first_function() called at " <<
72  Simulator::Now ().GetSeconds () << " s");
73  gFirstRun = true;
74 }
75 
78 {
79 public:
81  FakeNetDevice ();
83  void Doit3 (void);
84 };
85 
87 {
89 }
90 
91 void
93 {
95  sleep (1);
96  for (uint32_t i = 0; i < 10000; ++i)
97  {
98  //
99  // Exercise the realtime relative now path
100  //
102  usleep (1000);
103  }
104 }
105 
115 void
116 test (void)
117 {
118  GlobalValue::Bind ("SimulatorImplementationType",
119  StringValue ("ns3::RealtimeSimulatorImpl"));
120 
121  FakeNetDevice fnd;
122 
123  //
124  // Make sure ScheduleNow works when the system isn't running
125  //
127 
128  //
129  // drive the progression of m_currentTs at a ten millisecond rate from the main thread
130  //
131  for (double d = 0.; d < 14.999; d += 0.01)
132  {
134  }
135 
136  Ptr<SystemThread> st3 = Create<SystemThread> (
138  st3->Start ();
139 
140  Simulator::Stop (Seconds (15.0));
141  Simulator::Run ();
142  st3->Join ();
144 }
145 
146 int
147 main (int argc, char *argv[])
148 {
150  cmd.Parse (argc, argv);
151 
152  while (true)
153  {
154  test ();
155  }
156 }
157 
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:201
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:201
#define NS_LOG_FUNCTION_NOARGS()
Output the name of the function.
tuple cmd
Definition: second.py:35
FakeNetDevice()
Constructor.
static EventId Schedule(Time const &delay, MEM mem_ptr, OBJ obj)
Schedule an event to expire after delay.
Definition: simulator.h:1238
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
Definition: callback.h:1489
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:205
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
Definition: simulator.cc:165
Every class exported by the ns3 library is enclosed in the ns3 namespace.
void first_function(void)
An event method called once from the main thread.
#define NS_LOG_UNCOND(msg)
Output the requested message unconditionaly.
static Time Now(void)
Return the current simulation virtual time.
Definition: simulator.cc:224
Flag for events not associated with any particular context.
Definition: simulator.h:192
void Doit3(void)
The thread entry point.
static void ScheduleWithContext(uint32_t context, Time const &delay, MEM mem_ptr, OBJ obj)
Schedule an event with the given context.
Definition: simulator.h:1319
void background_function(void)
An event method called many times from the main thread.
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Definition: simulator.cc:209
bool gFirstRun
Check that the event functions run in the intended order.
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:895
void Join(void)
Suspend the caller until the thread of execution, running the provided callback, finishes.
void Parse(int argc, char *argv[])
Parse the program arguments.
Example class with a method for the background task.
void inserted_function(void)
An event method called many times from the background thread.
void test(void)
Example use of ns3::SystemThread.
EventImpl * MakeEvent(void(*f)(void))
Make an EventImpl from a function pointer taking varying numbers of arguments.
Definition: make-event.cc:34