Simple Point To Point Channel. More...
#include "point-to-point-channel.h"
Classes | |
class | Link |
Wire model for the PointToPointChannel. More... | |
Public Member Functions | |
PointToPointChannel () | |
Create a PointToPointChannel. More... | |
void | Attach (Ptr< PointToPointNetDevice > device) |
Attach a given netdevice to this channel. More... | |
virtual Ptr< NetDevice > | GetDevice (std::size_t i) const |
Get NetDevice corresponding to index i on this channel. More... | |
virtual std::size_t | GetNDevices (void) const |
Get number of devices on this channel. More... | |
Ptr< PointToPointNetDevice > | GetPointToPointDevice (std::size_t i) const |
Get PointToPointNetDevice corresponding to index i on this channel. More... | |
virtual bool | TransmitStart (Ptr< const Packet > p, Ptr< PointToPointNetDevice > src, Time txTime) |
Transmit a packet over this channel. More... | |
Public Member Functions inherited from ns3::Channel | |
Channel () | |
virtual | ~Channel () |
uint32_t | GetId (void) const |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. More... | |
virtual | ~Object () |
Destructor. More... | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. More... | |
void | Dispose (void) |
Dispose of this Object. More... | |
AggregateIterator | GetAggregateIterator (void) const |
Get an iterator to the Objects aggregated to this one. More... | |
virtual TypeId | GetInstanceTypeId (void) const |
Get the most derived TypeId for this Object. More... | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. More... | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (void) const |
Get a pointer to the requested aggregated Object. More... | |
void | Initialize (void) |
Invoke DoInitialize on all Objects aggregated to this one. More... | |
bool | IsInitialized (void) const |
Check if the object has been initialized. More... | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
SimpleRefCount () | |
Default constructor. More... | |
SimpleRefCount (const SimpleRefCount &o[[maybe_unused]]) | |
Copy constructor. More... | |
uint32_t | GetReferenceCount (void) const |
Get the reference count of the object. More... | |
SimpleRefCount & | operator= ([[maybe_unused]] const SimpleRefCount &o) |
Assignment operator. More... | |
void | Ref (void) const |
Increment the reference count. More... | |
void | Unref (void) const |
Decrement the reference count. More... | |
Public Member Functions inherited from ns3::ObjectBase | |
virtual | ~ObjectBase () |
Virtual destructor. More... | |
void | GetAttribute (std::string name, AttributeValue &value) const |
Get the value of an attribute, raising fatal errors if unsuccessful. More... | |
bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const |
Get the value of an attribute without raising erros. More... | |
void | SetAttribute (std::string name, const AttributeValue &value) |
Set a single attribute, raising fatal errors if unsuccessful. More... | |
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
Set a single attribute without raising errors. More... | |
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
Connect a TraceSource to a Callback with a context. More... | |
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
Connect a TraceSource to a Callback without a context. More... | |
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected with a context. More... | |
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected without a context. More... | |
Static Public Member Functions | |
static TypeId | GetTypeId (void) |
Get the TypeId. More... | |
Static Public Member Functions inherited from ns3::Channel | |
static TypeId | GetTypeId (void) |
Get the type ID. More... | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId (void) |
Register this type. More... | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId (void) |
Get the type ID. More... | |
Protected Types | |
typedef void(* | TxRxAnimationCallback) (Ptr< const Packet > packet, Ptr< NetDevice > txDevice, Ptr< NetDevice > rxDevice, Time duration, Time lastBitTime) |
TracedCallback signature for packet transmission animation events. More... | |
Protected Member Functions | |
Time | GetDelay (void) const |
Get the delay associated with this channel. More... | |
Ptr< PointToPointNetDevice > | GetDestination (uint32_t i) const |
Get the net-device destination. More... | |
Ptr< PointToPointNetDevice > | GetSource (uint32_t i) const |
Get the net-device source. More... | |
bool | IsInitialized (void) const |
Check to make sure the link is initialized. More... | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. More... | |
virtual void | DoDispose (void) |
Destructor implementation. More... | |
virtual void | DoInitialize (void) |
Initialize() implementation. More... | |
virtual void | NotifyNewAggregate (void) |
Notify all Objects aggregated to this one of a new Object being aggregated. More... | |
Protected Member Functions inherited from ns3::ObjectBase | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. More... | |
virtual void | NotifyConstructionCompleted (void) |
Notifier called once the ObjectBase is fully constructed. More... | |
Private Types | |
enum | WireState { INITIALIZING , IDLE , TRANSMITTING , PROPAGATING } |
Wire states. More... | |
Private Attributes | |
Time | m_delay |
Propagation delay. More... | |
Link | m_link [N_DEVICES] |
Link model. More... | |
std::size_t | m_nDevices |
Devices of this channel. More... | |
TracedCallback< Ptr< const Packet >, Ptr< NetDevice >, Ptr< NetDevice >, Time, Time > | m_txrxPointToPoint |
The trace source for the packet transmission animation events that the device can fire. More... | |
Static Private Attributes | |
static const std::size_t | N_DEVICES = 2 |
Each point to point link has exactly two net devices. More... | |
Additional Inherited Members | |
Related Functions inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid (void) |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. More... | |
Simple Point To Point Channel.
This class represents a very simple point to point channel. Think full duplex RS-232 or RS-422 with null modem and no handshaking. There is no multi-drop capability on this channel – there can be a maximum of two point-to-point net devices connected.
There are two "wires" in the channel. The first device connected gets the [0] wire to transmit on. The second device gets the [1] wire. There is a state (IDLE, TRANSMITTING) associated with each wire.
ns3::PointToPointChannel is accessible through the following paths with Config::Set and Config::Connect:
Size of this type is 120 bytes (on a 64-bit architecture).
Definition at line 50 of file point-to-point-channel.h.
|
protected |
TracedCallback signature for packet transmission animation events.
[in] | packet | The packet being transmitted. |
[in] | txDevice | the TransmitTing NetDevice. |
[in] | rxDevice | the Receiving NetDevice. |
[in] | duration | The amount of time to transmit the packet. |
[in] | lastBitTime | Last bit receive time (relative to now) |
Ptr<NetDevice>
argument is deprecated and will be changed to Ptr<const NetDevice>
in a future release. Definition at line 143 of file point-to-point-channel.h.
|
private |
Wire states.
Enumerator | |
---|---|
INITIALIZING | Initializing state. |
IDLE | Idle state (no transmission from NetDevice) |
TRANSMITTING | Transmitting state (data being transmitted from NetDevice. |
PROPAGATING | Propagating state (data is being propagated in the channel. |
Definition at line 176 of file point-to-point-channel.h.
ns3::PointToPointChannel::PointToPointChannel | ( | ) |
Create a PointToPointChannel.
By default, you get a channel that has an "infinitely" fast transmission speed and zero delay.
Definition at line 56 of file point-to-point-channel.cc.
References NS_LOG_FUNCTION_NOARGS.
void ns3::PointToPointChannel::Attach | ( | Ptr< PointToPointNetDevice > | device | ) |
Attach a given netdevice to this channel.
device | pointer to the netdevice to attach to the channel |
Definition at line 66 of file point-to-point-channel.cc.
References IDLE, ns3::PointToPointChannel::Link::m_dst, m_link, m_nDevices, ns3::PointToPointChannel::Link::m_src, ns3::PointToPointChannel::Link::m_state, N_DEVICES, NS_ASSERT, NS_ASSERT_MSG, and NS_LOG_FUNCTION.
|
protected |
Get the delay associated with this channel.
Definition at line 132 of file point-to-point-channel.cc.
References m_delay.
Referenced by ns3::PointToPointRemoteChannel::TransmitStart().
|
protected |
Get the net-device destination.
i | the link requested |
Definition at line 144 of file point-to-point-channel.cc.
References ns3::PointToPointChannel::Link::m_dst, and m_link.
Referenced by ns3::PointToPointRemoteChannel::TransmitStart().
Get NetDevice corresponding to index i on this channel.
i | Index number of the device requested |
Implements ns3::Channel.
Definition at line 125 of file point-to-point-channel.cc.
References GetPointToPointDevice(), and NS_LOG_FUNCTION_NOARGS.
|
virtual |
Get number of devices on this channel.
Implements ns3::Channel.
Definition at line 110 of file point-to-point-channel.cc.
References m_nDevices, and NS_LOG_FUNCTION_NOARGS.
Ptr< PointToPointNetDevice > ns3::PointToPointChannel::GetPointToPointDevice | ( | std::size_t | i | ) | const |
Get PointToPointNetDevice corresponding to index i on this channel.
i | Index number of the device requested |
Definition at line 117 of file point-to-point-channel.cc.
References m_link, ns3::PointToPointChannel::Link::m_src, NS_ASSERT, and NS_LOG_FUNCTION_NOARGS.
Referenced by GetDevice().
|
protected |
Get the net-device source.
i | the link requested |
Definition at line 138 of file point-to-point-channel.cc.
References m_link, and ns3::PointToPointChannel::Link::m_src.
Referenced by ns3::PointToPointRemoteChannel::TransmitStart().
|
static |
Get the TypeId.
Definition at line 33 of file point-to-point-channel.cc.
References m_delay, m_txrxPointToPoint, ns3::MakeTimeAccessor(), ns3::MakeTimeChecker(), ns3::MakeTraceSourceAccessor(), ns3::Seconds(), and ns3::TypeId::SetParent().
|
protected |
Check to make sure the link is initialized.
Definition at line 150 of file point-to-point-channel.cc.
References INITIALIZING, m_link, and NS_ASSERT.
Referenced by ns3::PointToPointRemoteChannel::TransmitStart().
|
virtual |
Transmit a packet over this channel.
p | Packet to transmit |
src | Source PointToPointNetDevice |
txTime | Transmit time to apply |
Reimplemented in ns3::PointToPointRemoteChannel.
Definition at line 87 of file point-to-point-channel.cc.
References ns3::Packet::Copy(), ns3::Packet::GetUid(), INITIALIZING, m_delay, ns3::PointToPointChannel::Link::m_dst, m_link, ns3::PointToPointChannel::Link::m_src, m_txrxPointToPoint, NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, ns3::PointToPointNetDevice::Receive(), and ns3::Simulator::ScheduleWithContext().
|
private |
Propagation delay.
Definition at line 152 of file point-to-point-channel.h.
Referenced by GetDelay(), GetTypeId(), and TransmitStart().
Link model.
Definition at line 204 of file point-to-point-channel.h.
Referenced by Attach(), GetDestination(), GetPointToPointDevice(), GetSource(), IsInitialized(), and TransmitStart().
|
private |
Devices of this channel.
Definition at line 153 of file point-to-point-channel.h.
Referenced by Attach(), and GetNDevices().
|
private |
The trace source for the packet transmission animation events that the device can fire.
Arguments to the callback are the packet, transmitting net device, receiving net device, transmission time and packet receipt time.
Ptr<NetDevice>
argument is deprecated and will be changed to Ptr<const NetDevice>
in a future release. Definition at line 171 of file point-to-point-channel.h.
Referenced by GetTypeId(), and TransmitStart().
|
staticprivate |
Each point to point link has exactly two net devices.
Definition at line 150 of file point-to-point-channel.h.
Referenced by Attach().