22 #include "ns3/core-module.h"
24 #include "ns3/dsr-module.h"
25 #include "ns3/internet-module.h"
27 #include "ns3/lr-wpan-mac.h"
28 #include "ns3/lte-module.h"
31 #include "ns3/mesh-module.h"
32 #include "ns3/mobility-module.h"
33 #include "ns3/network-module.h"
34 #include "ns3/olsr-module.h"
35 #include "ns3/sixlowpan-module.h"
36 #include "ns3/spectrum-module.h"
37 #include "ns3/stats-module.h"
38 #include "ns3/uan-module.h"
39 #include "ns3/wifi-module.h"
68 template <
typename T1,
typename T2,
typename T3,
typename T4,
typename T5>
72 template <
typename T1,
typename T2,
typename T3,
typename T4,
typename T5>
75 template <
typename T1,
typename T2,
typename T3,
typename T4>
78 template <
typename T1,
typename T2,
typename T3>
82 template <
typename T1,
typename T2>
85 template <
typename T1>
88 virtual void DoRun (
void);
101 std::set<std::string>
104 std::set<std::string> dupes;
106 dupes.insert (
"LteRlc::NotifyTxTracedCallback");
107 dupes.insert (
"LteRlc::ReceiveTracedCallback");
108 dupes.insert (
"LteUeRrc::ImsiCidRntiTracedCallback");
109 dupes.insert (
"LteUeRrc::MibSibHandoverTracedCallback");
110 dupes.insert (
"WifiPhyStateHelper::RxEndErrorTracedCallback");
128 template <
typename T>
inline
131 #define TYPENAME(T) \
132 template <> inline std::string \
133 TypeName < T > (int N) \
135 std::stringstream ss; \
136 ss << # T << "(" << N << ")"; \
214 std::cout <<
"with " << N <<
" args." << std::endl;
222 template <
typename T1,
typename T2,
typename T3,
typename T4,
typename T5>
226 static void Sink (T1 a1, T2 a2, T3 a3, T4 a4, T5 a5) {
SinkIt (5); }
229 template <
typename T1,
typename T2,
typename T3,
typename T4>
233 static void Sink (T1 a1, T2 a2, T3 a3, T4 a4) {
SinkIt (4); }
236 template <
typename T1,
typename T2,
typename T3>
243 template <
typename T1,
typename T2>
250 template <
typename T1>
273 template <
typename T1,
typename T2,
typename T3,
typename T4,
typename T5>
285 if (m_nArgs == 0) std::cout << std::endl;
291 template <
typename T1,
typename T2,
typename T3,
typename T4,
typename T5>
297 template <
typename U>
301 U
sink = TracedCbSink<T1, T2, T3, T4, T5>::Sink;
304 std::cout << TypeName<U> (N) <<
" invoked ";
306 m_cb (this->
m1, this->
m2, this->m3, this->m4, this->m5);
311 template <
typename T1,
typename T2,
typename T3,
typename T4>
318 template <
typename U>
322 U
sink = TracedCbSink<T1, T2, T3, T4, empty>::Sink;
325 std::cout << TypeName<U> (N) <<
" invoked ";
327 m_cb (this->
m1, this->
m2, this->m3, this->m4);
332 template <
typename T1,
typename T2,
typename T3>
339 template <
typename U>
343 U
sink = TracedCbSink<T1, T2, T3, empty, empty>::Sink;
346 std::cout << TypeName<U> (N) <<
" invoked ";
348 m_cb (this->
m1, this->
m2, this->m3);
353 template <
typename T1,
typename T2>
360 template <
typename U>
364 U
sink = TracedCbSink<T1, T2, empty, empty, empty>::Sink;
367 std::cout << TypeName<U> (N) <<
" invoked ";
369 m_cb (this->
m1, this->
m2);
374 template <
typename T1>
376 :
public CheckerBase<T1, empty, empty, empty, empty>
381 template <
typename U>
385 U
sink = TracedCbSink<T1, empty, empty, empty, empty>::Sink;
388 std::cout << TypeName<U> (N) <<
" invoked ";
396 :
TestCase (
"Check basic TracedCallback operation")
404 #define DUPE(U, T1) \
405 if (g_dupes.find ( # U ) == g_dupes.end ()) \
406 NS_TEST_ASSERT_MSG_NE (0, 1, \
407 "expected to find " << # U << " in dupes."); \
408 if (TypeName<U> (0) == TypeName<T1> (0)) \
409 std::cout << # U << " matches " << # T1 << std::endl; \
411 NS_TEST_ASSERT_MSG_EQ \
412 (TypeName<U> (0), TypeName<T1> (0), \
413 "the typedef " << # U << \
414 " used to match the typedef " << # T1 << \
415 " but no longer does. Please add a new CHECK call.")
417 #define CHECK(U, T1, T2, T3, T4, T5) \
418 CreateObject< Checker<T1, T2, T3, T4, T5> > () -> Invoke<U> ()
420 CHECK (dsr::DsrOptionSRHeader::TracedCallback,
424 CHECK (EpcUeNas::StateTracedCallback,
428 CHECK (Ipv4L3Protocol::DropTracedCallback,
432 CHECK (Ipv4L3Protocol::SentTracedCallback,
436 CHECK (Ipv4L3Protocol::TxRxTracedCallback,
440 CHECK (Ipv6L3Protocol::DropTracedCallback,
445 CHECK (Ipv6L3Protocol::SentTracedCallback,
449 CHECK (Ipv6L3Protocol::TxRxTracedCallback,
453 CHECK (LrWpanMac::SentTracedCallback,
457 CHECK (LrWpanMac::StateTracedCallback,
461 CHECK (LrWpanPhy::StateTracedCallback,
472 CHECK (LteEnbMac::UlSchedulingTracedCallback,
473 uint32_t, uint32_t, uint16_t, uint8_t, uint16_t);
475 CHECK (LteEnbPhy::ReportUeSinrTracedCallback,
476 uint16_t, uint16_t,
double,
479 CHECK (LteEnbPhy::ReportInterferenceTracedCallback,
483 CHECK (LteEnbRrc::ConnectionHandoverTracedCallback,
484 uint64_t, uint16_t, uint16_t,
487 CHECK (LteEnbRrc::HandoverStartTracedCallback,
488 uint64_t, uint16_t, uint16_t, uint16_t,
491 CHECK (LteEnbRrc::NewUeContextTracedCallback,
495 CHECK (LteEnbRrc::ReceiveReportTracedCallback,
499 CHECK (LtePdcp::PduRxTracedCallback,
500 uint16_t, uint8_t, uint32_t, uint64_t,
503 CHECK (LtePdcp::PduTxTracedCallback,
504 uint16_t, uint8_t, uint32_t,
507 DUPE (LteRlc::NotifyTxTracedCallback, LtePdcp::PduTxTracedCallback);
509 DUPE (LteRlc::ReceiveTracedCallback, LtePdcp::PduRxTracedCallback);
511 CHECK (LteUePhy::RsrpSinrTracedCallback,
512 uint16_t, uint16_t,
double,
double,
515 CHECK (LteUePhy::RsrpRsrqTracedCallback,
516 uint16_t, uint16_t,
double,
double,
bool);
518 CHECK (LteUePhy::StateTracedCallback,
522 DUPE (LteUePowerControl::TxPowerTracedCallback, LteEnbPhy::ReportUeSinrTracedCallback);
524 CHECK (LteUeRrc::CellSelectionTracedCallback,
528 DUPE (LteUeRrc::ImsiCidRntiTracedCallback, LteEnbRrc::ConnectionHandoverTracedCallback);
530 DUPE (LteUeRrc::MibSibHandoverTracedCallback, LteEnbRrc::HandoverStartTracedCallback);
532 CHECK (LteUeRrc::StateTracedCallback,
535 CHECK (Mac48Address::TracedCallback,
539 CHECK (MobilityModel::TracedCallback,
543 CHECK (olsr::RoutingProtocol::PacketTxRxTracedCallback,
547 CHECK (olsr::RoutingProtocol::TableChangeTracedCallback,
551 CHECK (Packet::AddressTracedCallback,
555 CHECK (Packet::Mac48AddressTracedCallback,
559 CHECK (Packet::SinrTracedCallback,
563 CHECK (Packet::SizeTracedCallback,
567 CHECK (Packet::TracedCallback,
571 CHECK (PacketBurst::TracedCallback,
575 CHECK (dot11s::PeerManagementProtocol::LinkOpenCloseTracedCallback,
579 CHECK (PhyReceptionStatParameters::TracedCallback,
583 CHECK (PhyTransmissionStatParameters::TracedCallback,
587 CHECK (SixLowPanNetDevice::DropTracedCallback,
592 CHECK (SixLowPanNetDevice::RxTxTracedCallback,
596 CHECK (SpectrumChannel::LossTracedCallback,
600 CHECK (SpectrumValue::TracedCallback,
604 CHECK (TimeSeriesAdaptor::OutputTracedCallback,
608 CHECK (UanMac::PacketModeTracedCallback,
612 CHECK (UanMacCw::QueueTracedCallback,
616 CHECK (UanMacRc::QueueTracedCallback,
620 CHECK (UanNetDevice::RxTxTracedCallback,
624 CHECK (UanPhy::TracedCallback,
628 CHECK (UeManager::StateTracedCallback,
631 CHECK (WifiMacHeader::TracedCallback,
635 CHECK (WifiPhyStateHelper::RxEndErrorTracedCallback,
639 CHECK (WifiPhyStateHelper::RxOkTracedCallback,
643 CHECK (WifiPhyStateHelper::StateTracedCallback,
647 CHECK (WifiPhyStateHelper::TxTracedCallback,
651 CHECK (WifiRemoteStationManager::PowerChangeTracedCallback,
655 CHECK (WifiRemoteStationManager::RateChangeTracedCallback,
667 :
TestSuite (
"traced-callback-typedef", SYSTEM)
static void Sink(T1 a1, T2 a2, T3 a3, T4 a4)
void(* Mac48AddressTracedCallback)(Ptr< const Packet > packet, Mac48Address mac)
TracedCallback signature for packet and Mac48Address.
Simulation virtual time values and global simulation resolution.
static void Sink(T1 a1, T2 a2, T3 a3, T4 a4, T5 a5)
void(* StateTracedCallback)(Time time, LrWpanPhyEnumeration oldState, LrWpanPhyEnumeration newState)
TracedCallback signature for Trx state change events.
TracedCallback< T1, T2, T3 > m_cb
void(* QueueTracedCallback)(Ptr< const Packet > packet, uint32_t proto)
TracedCallback signature for dequeue of a packet.
void(* StateTracedCallback)(Time start, Time duration, WifiPhy::State state)
TracedCallback signature for state changes.
void(* QueueTracedCallback)(Ptr< const Packet > packet, uint16_t proto)
TracedCallback signature for enqueue/dequeue of a packet.
void(* StateTracedCallback)(const State oldState, const State newState)
TracedCallback signature for state change events.
void(* SizeTracedCallback)(uint32_t oldSize, uint32_t newSize)
TracedCallback signature for changes in packet size.
void(* TracedCallback)(Ptr< const Packet > packet)
TracedCallback signature for Ptr
TypeTraits< T5 >::BaseType m5
void(* RateChangeTracedCallback)(uint32_t rate, Mac48Address remoteAddress)
TracedCallback signature for rate change events.
void(* PduTxTracedCallback)(uint16_t rnti, uint8_t lcid, uint32_t size)
TracedCallback for PDU transmission event.
void(* TableChangeTracedCallback)(uint32_t size)
TracedCallback signature for routing table computation.
void(* ReportUeSinrTracedCallback)(uint16_t cellId, uint16_t rnti, double sinrLinear)
TracedCallback signature for the linear average of SRS SINRs.
static void Sink(T1 a1, T2 a2, T3 a3)
DropReason
Enumeration of the dropping reasons in SixLoWPAN.
void(* ReportInterferenceTracedCallback)(uint16_t cellId, Ptr< SpectrumValue > spectrumValue)
TracedCallback signature for the linear average of SRS SINRs.
State
The states of the UE PHY entity.
represent a single transmission modeA WifiMode is implemented by a single integer which is used to lo...
TracedCallback< T1 > m_cb
std::string TypeName(int N)
Stringify the known TracedCallback type names.
void(* StateTracedCallback)(uint64_t imsi, uint16_t cellId, uint16_t rnti, State oldState, State newState)
TracedCallback signature for state transition events.
a polymophic address class
DropReason
Reason why a packet has been dropped.
TracedCallback< T1, T2, T3, T4, T5 > m_cb
void(* PacketModeTracedCallback)(Ptr< const Packet > packet, UanTxMode mode)
TracedCallback signature for packet reception/enqueue/dequeue events.
WifiPreamble
The type of preamble to be used by an IEEE 802.11 transmission.
void(* StateTracedCallback)(uint16_t cellId, uint16_t rnti, State oldState, State newState)
TracedCallback signature for state transition events.
make Callback use a separate empty type
void(* AddressTracedCallback)(Ptr< const Packet > packet, const Address &address)
TracedCallback signature for packet and Address.
void AddTestCase(TestCase *testCase, enum TestDuration duration)
Add an individual child TestCase to this test suite.
void(* DropTracedCallback)(const Ipv6Header &header, Ptr< const Packet > packet, DropReason reason, Ptr< Ipv6 > ipv6, uint32_t interface)
TracedCallback signature for packet drop events.
void(* RxOkTracedCallback)(Ptr< const Packet > packet, double snr, WifiMode mode, WifiPreamble preamble)
TracedCallback signature for receive end ok event.
A class used for addressing UAN MAC's.
void(* TxRxTracedCallback)(Ptr< const Packet > packet, Ptr< Ipv6 > ipv6, uint32_t interface)
TracedCallback signature for packet transmission or reception events.
static int m_nArgs
Number of arguments passed to callback.
Abstraction of packet modulation information.
void(* PduRxTracedCallback)(const uint16_t rnti, const uint8_t lcid, const uint32_t size, const uint64_t delay)
TracedCallback signature for PDU receive event.
TracedCallback< T1, T2, T3, T4 > m_cb
virtual ~TracedCallbackTypedefTestCase()
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
void(* TxTracedCallback)(Ptr< const Packet > packet, WifiMode mode, WifiPreamble preamble, uint8_t power)
TracedCallback signature for transmit event.
void(* SinrTracedCallback)(Ptr< const Packet > packet, double sinr)
TracedCallback signature for packet and SINR.
void(* LossTracedCallback)(Ptr< SpectrumPhy > txPhy, Ptr< SpectrumPhy > rxPhy, double lossDb)
TracedCallback signature for path loss calculation events.
void(* TracedCallback)(Ptr< SpectrumValue > value)
TracedCallback signature for SpectrumValue.
void SinkIt(unsigned int N)
Log that a callback was invoked.
virtual void DoRun(void)
Implementation to actually run this TestCase.
void(* TracedCallback)(const PhyReceptionStatParameters params)
TracedCallback signature.
TracedCallback< T1, T2 > m_cb
void(* TracedCallback)(Mac48Address value)
TracedCallback signature for Mac48Address.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
State
The state of the UeManager at the eNB RRC.
void(* LinkOpenCloseTracedCallback)(Mac48Address src, const Mac48Address dst)
TracedCallback signature for link open/close events.
std::set< std::string > g_dupes
Container for duplicate types.
void(* ReceiveReportTracedCallback)(uint64_t imsi, uint16_t cellId, uint16_t rnti, LteRrcSap::MeasurementReport report)
TracedCallback signature for receive measurement report events.
void(* NewUeContextTracedCallback)(uint16_t cellId, uint16_t rnti)
TracedCallback signature for new Ue Context events.
void(* RxTxTracedCallback)(Ptr< const Packet > packet, UanAddress address)
TracedCallback signature for MAC send/receive events.
void(* UlSchedulingTracedCallback)(uint32_t frame, uint32_t subframe, uint16_t rnti, uint8_t mcs, uint16_t tbsSize)
TracedCallback signature for UL scheduling events.
TypeTraits< T4 >::BaseType m4
std::vector< MessageHeader > MessageList
static TracedCallbackTypedefTestSuite tracedCallbackTypedefTestSuite
TracedCallbackTypedefTestCase()
void(* DropTracedCallback)(DropReason reason, Ptr< const Packet > packet, Ptr< SixLowPanNetDevice > sixNetDevice, uint32_t ifindex)
TracedCallback signature for.
void(* OutputTracedCallback)(const double now, const double data)
TracedCallback signature for output trace.
void(* SentTracedCallback)(const Ipv6Header &header, Ptr< const Packet > packet, uint32_t interface)
TracedCallback signature for packet sent, forwarded or local-delivered events.
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
void(* SentTracedCallback)(const Ipv4Header &header, Ptr< const Packet > packet, uint32_t interface)
TracedCallback signature for packet send, forward, or local deliver events.
State
The states of the UE RRC entity.
void(* TracedCallback)(Ptr< const Packet > pkt, double sinr, UanTxMode mode)
TracedCallback signature for UanPhy packet send/receive events.
void(* PacketTxRxTracedCallback)(const PacketHeader &header, const MessageList &messages)
TracedCallback signature for Packet transmit and receive events.
TypeTraits< T3 >::BaseType m3
void(* TracedCallback)(Ptr< const PacketBurst > burst)
TracedCallback signature for Ptr
void(* TracedCallback)(Ptr< const MobilityModel > model)
TracedCallback signature.
TracedCallbackTypedefTestSuite()
void ConnectWithoutContext(const CallbackBase &callback)
Append a Callback to the chain (without a context).
State
Definition of NAS states as per "LTE - From theory to practice", Section 3.2.3.2 "Connection Establis...
void(* RsrpRsrqTracedCallback)(uint16_t rnti, uint16_t cellId, double rsrp, double rsrq, bool isServingCell)
TracedCallback signature for cell RSRP and RSRQ.
void(* RxTxTracedCallback)(Ptr< const Packet > packet, Ptr< SixLowPanNetDevice > sixNetDevice, uint32_t ifindex)
TracedCallback signature for packet send/receive events.
void(* StateTracedCallback)(uint64_t imsi, uint16_t cellId, uint16_t rnti, State oldState, State newState)
TracedCallback signature for state transition events.
static void Sink(T1 a1, T2 a2)
Inspect a type to deduce its features.
void(* TracedCallback)(const PhyTransmissionStatParameters params)
TracedCallback signature.
const double m2
Second component modulus, 232 - 22853.
void(* HandoverStartTracedCallback)(uint64_t imsi, uint16_t cellId, uint16_t rnti, uint16_t targetCid)
TracedCallback signature for handover start events.
void(* PowerChangeTracedCallback)(uint8_t power, Mac48Address remoteAddress)
TracedCallback signature for power change events.
LrWpanMacState
MAC states.
DropReason
Reason why a packet has been dropped.
void(* StateTracedCallback)(LrWpanMacState oldState, LrWpanMacState newState)
TracedCallback signature for LrWpanMacState change events.
TypeTraits< T1 >::BaseType m1
LrWpanPhyEnumeration
IEEE802.15.4-2006 PHY Emumerations Table 18 in section 6.2.3.
A base class which provides memory management and object aggregation.
void(* TxRxTracedCallback)(Ptr< const Packet > packet, Ptr< Ipv4 > ipv4, uint32_t interface)
TracedCallback signature for packet transmission or reception events.
void(* RsrpSinrTracedCallback)(uint16_t cellId, uint16_t rnti, double rsrp, double sinr)
TracedCallback signature for cell RSRP and SINR report.
State
The state of the PHY layer.
const double m1
First component modulus, 232 - 209.
std::set< std::string > Duplicates(void)
Record typedefs which are identical to previously declared.
void(* CellSelectionTracedCallback)(uint64_t imsi, uint16_t cellId)
TracedCallback signature for imsi, cellId and rnti events.
TypeTraits< T2 >::BaseType m2
#define CHECK(U, T1, T2, T3, T4, T5)
void(* SentTracedCallback)(Ptr< const Packet > packet, uint8_t retries, uint8_t backoffs)
TracedCallback signature for sent packets.
void(* ConnectionHandoverTracedCallback)(uint64_t imsi, uint16_t cellId, uint16_t rnti)
TracedCallback signature for connection and handover end events.
void(* DropTracedCallback)(const Ipv4Header &header, Ptr< const Packet > packet, DropReason reason, Ptr< Ipv4 > ipv4, uint32_t interface)
TracedCallback signature for packet drop events.