A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
ns3::LteEnbNetDevice Class Reference

#include <lte-enb-net-device.h>

+ Inheritance diagram for ns3::LteEnbNetDevice:

Public Member Functions

virtual void DoDispose (void)
 
uint16_t GetCellId () const
 
uint8_t GetDlBandwidth () const
 
uint16_t GetDlEarfcn () const
 
Ptr< LteEnbMacGetMac (void) const
 
Ptr< LteEnbPhyGetPhy (void) const
 
Ptr< LteEnbRrcGetRrc () const
 
uint8_t GetUlBandwidth () const
 
uint16_t GetUlEarfcn () const
 
virtual bool Send (Ptr< Packet > packet, const Address &dest, uint16_t protocolNumber)
 
void SetDlBandwidth (uint8_t bw)
 
void SetDlEarfcn (uint16_t earfcn)
 
void SetUlBandwidth (uint8_t bw)
 
void SetUlEarfcn (uint16_t earfcn)
 
- Public Member Functions inherited from ns3::LteNetDevice
virtual void AddLinkChangeCallback (Callback< void > callback)
 
virtual Address GetAddress (void) const
 
virtual Address GetBroadcast (void) const
 
virtual Ptr< ChannelGetChannel (void) const
 
virtual uint32_t GetIfIndex (void) const
 
virtual uint16_t GetMtu (void) const
 
virtual Address GetMulticast (Ipv4Address addr) const
 Make and return a MAC multicast address using the provided multicast group. More...
 
virtual Address GetMulticast (Ipv6Address addr) const
 Get the MAC multicast address corresponding to the IPv6 address provided. More...
 
virtual Ptr< NodeGetNode (void) const
 
virtual bool IsBridge (void) const
 Return true if the net device is acting as a bridge. More...
 
virtual bool IsBroadcast (void) const
 
virtual bool IsLinkUp (void) const
 
virtual bool IsMulticast (void) const
 
virtual bool IsPointToPoint (void) const
 Return true if the net device is on a point-to-point link. More...
 
virtual bool NeedsArp (void) const
 
void Receive (Ptr< Packet > p)
 
virtual bool SendFrom (Ptr< Packet > packet, const Address &source, const Address &dest, uint16_t protocolNumber)
 
virtual void SetAddress (Address address)
 
virtual void SetIfIndex (const uint32_t index)
 
virtual bool SetMtu (const uint16_t mtu)
 
virtual void SetNode (Ptr< Node > node)
 
virtual void SetPromiscReceiveCallback (PromiscReceiveCallback cb)
 
virtual void SetReceiveCallback (NetDevice::ReceiveCallback cb)
 
virtual bool SupportsSendFrom (void) const
 
- Public Member Functions inherited from ns3::Object
void AggregateObject (Ptr< Object > other)
 
void Dispose (void)
 
AggregateIterator GetAggregateIterator (void) const
 
virtual TypeId GetInstanceTypeId (void) const
 
template<typename T >
Ptr< T > GetObject (void) const
 
template<typename T >
Ptr< T > GetObject (TypeId tid) const
 
void Initialize (void)
 
- Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
 SimpleRefCount (const SimpleRefCount &o)
 
uint32_t GetReferenceCount (void) const
 
SimpleRefCountoperator= (const SimpleRefCount &o)
 
void Ref (void) const
 
void Unref (void) const
 
- Public Member Functions inherited from ns3::ObjectBase
void GetAttribute (std::string name, AttributeValue &value) const
 
bool GetAttributeFailSafe (std::string name, AttributeValue &attribute) const
 
void SetAttribute (std::string name, const AttributeValue &value)
 
bool SetAttributeFailSafe (std::string name, const AttributeValue &value)
 
bool TraceConnect (std::string name, std::string context, const CallbackBase &cb)
 
bool TraceConnectWithoutContext (std::string name, const CallbackBase &cb)
 
bool TraceDisconnect (std::string name, std::string context, const CallbackBase &cb)
 
bool TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb)
 

Static Public Member Functions

static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::LteNetDevice
static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::NetDevice
static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::Object
static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
static void Cleanup (void)
 
- Static Public Member Functions inherited from ns3::ObjectBase
static TypeId GetTypeId (void)
 

Protected Member Functions

virtual void DoInitialize (void)
 
- Protected Member Functions inherited from ns3::Object
 Object (const Object &o)
 
virtual void NotifyNewAggregate (void)
 
- Protected Member Functions inherited from ns3::ObjectBase
void ConstructSelf (const AttributeConstructionList &attributes)
 
virtual void NotifyConstructionCompleted (void)
 

Private Member Functions

void UpdateConfig (void)
 

Private Attributes

uint16_t m_cellId
 
uint8_t m_dlBandwidth
 
uint16_t m_dlEarfcn
 
Ptr< LteEnbMacm_mac
 
Ptr< LteEnbPhym_phy
 
Ptr< LteEnbRrcm_rrc
 
Ptr< FfMacSchedulerm_scheduler
 
uint8_t m_ulBandwidth
 
uint16_t m_ulEarfcn
 

Additional Inherited Members

- Public Types inherited from ns3::NetDevice
enum  PacketType {
  PACKET_HOST = 1, NS3_PACKET_HOST = PACKET_HOST, PACKET_BROADCAST, NS3_PACKET_BROADCAST = PACKET_BROADCAST,
  PACKET_MULTICAST, NS3_PACKET_MULTICAST = PACKET_MULTICAST, PACKET_OTHERHOST, NS3_PACKET_OTHERHOST = PACKET_OTHERHOST
}
 
typedef Callback< bool, Ptr
< NetDevice >, Ptr< const
Packet >, uint16_t, const
Address &, const Address
&, enum PacketType
PromiscReceiveCallback
 
typedef Callback< bool, Ptr
< NetDevice >, Ptr< const
Packet >, uint16_t, const
Address & > 
ReceiveCallback
 
- Protected Attributes inherited from ns3::LteNetDevice
NetDevice::ReceiveCallback m_rxCallback
 

Detailed Description

The eNodeB device implementation

Config Paths

ns3::LteEnbNetDevice is accessible through the following paths with Config::Set and Config::Connect:

  • /NodeList/[i]/DeviceList/[i]/$ns3::LteEnbNetDevice
  • /NodeList/[i]/DeviceList/[i]/$ns3::LteNetDevice/$ns3::LteEnbNetDevice

Attributes

  • LteEnbRrc: The RRC associated to this EnbNetDevice
    • Set with class: ns3::PointerValue
    • Underlying type: ns3::Ptr< ns3::LteEnbRrc >
    • Initial value: 0
    • Flags: construct write read
  • LteEnbMac: The MAC associated to this EnbNetDevice
    • Set with class: ns3::PointerValue
    • Underlying type: ns3::Ptr< ns3::LteEnbMac >
    • Initial value: 0
    • Flags: construct write read
  • FfMacScheduler: The scheduler associated to this EnbNetDevice
    • Set with class: ns3::PointerValue
    • Underlying type: ns3::Ptr< ns3::FfMacScheduler >
    • Initial value: 0
    • Flags: construct write read
  • LteEnbPhy: The PHY associated to this EnbNetDevice
    • Set with class: ns3::PointerValue
    • Underlying type: ns3::Ptr< ns3::LteEnbPhy >
    • Initial value: 0
    • Flags: construct write read
  • UlBandwidth: Uplink Transmission Bandwidth Configuration in number of Resource Blocks
  • DlBandwidth: Downlink Transmission Bandwidth Configuration in number of Resource Blocks
  • CellId: Cell Identifier
  • DlEarfcn: Downlink E-UTRA Absolute Radio Frequency Channel Number (EARFCN) as per 3GPP 36.101 Section 5.7.3.
  • UlEarfcn: Uplink E-UTRA Absolute Radio Frequency Channel Number (EARFCN) as per 3GPP 36.101 Section 5.7.3.

Attributes defined in parent class ns3::LteNetDevice

  • Mtu: The MAC-level Maximum Transmission Unit

No TraceSources are defined for this type.

Definition at line 50 of file lte-enb-net-device.h.

Member Function Documentation

void ns3::LteEnbNetDevice::DoDispose ( void  )
virtual

This method is called by Object::Dispose or by the object's destructor, whichever comes first.

Subclasses are expected to implement their real destruction code in an overriden version of this method and chain up to their parent's implementation once they are done. i.e., for simplicity, the destructor of every subclass should be empty and its content should be moved to the associated DoDispose method.

It is safe to call GetObject from within this method.

Reimplemented from ns3::LteNetDevice.

Definition at line 122 of file lte-enb-net-device.cc.

References ns3::LteNetDevice::DoDispose(), and NS_LOG_FUNCTION.

void ns3::LteEnbNetDevice::DoInitialize ( void  )
protectedvirtual

This method is called only once by Object::Initialize. If the user calls Object::Initialize multiple times, DoInitialize is called only the first time.

Subclasses are expected to override this method and chain up to their parent's implementation once they are done. It is safe to call GetObject and AggregateObject from within this method.

Reimplemented from ns3::Object.

Definition at line 249 of file lte-enb-net-device.cc.

References UpdateConfig().

uint16_t ns3::LteEnbNetDevice::GetCellId ( ) const
Returns
the Cell Identifier of this eNB

Definition at line 166 of file lte-enb-net-device.cc.

References m_cellId.

Referenced by ns3::EpcHelper::AddX2Interface().

uint8_t ns3::LteEnbNetDevice::GetDlBandwidth ( ) const
Returns
the downlink bandwidth in RBs

Definition at line 198 of file lte-enb-net-device.cc.

References m_dlBandwidth.

uint16_t ns3::LteEnbNetDevice::GetDlEarfcn ( ) const
Returns
the downlink carrier frequency (EARFCN)

Definition at line 224 of file lte-enb-net-device.cc.

References m_dlEarfcn.

Ptr< LteEnbMac > ns3::LteEnbNetDevice::GetMac ( void  ) const
Returns
a pointer to the MAC

Definition at line 144 of file lte-enb-net-device.cc.

References NS_LOG_FUNCTION.

Ptr< LteEnbPhy > ns3::LteEnbNetDevice::GetPhy ( void  ) const
Returns
a pointer to the physical layer.

Definition at line 152 of file lte-enb-net-device.cc.

References NS_LOG_FUNCTION.

Referenced by LenaFdMtFfMacSchedulerTestCase::DoRun(), LenaTtaFfMacSchedulerTestCase::DoRun(), and LenaTdMtFfMacSchedulerTestCase::DoRun().

Ptr< LteEnbRrc > ns3::LteEnbNetDevice::GetRrc ( ) const
Returns
a pointer to the Radio Resource Control instance of the eNB

Definition at line 160 of file lte-enb-net-device.cc.

uint8_t ns3::LteEnbNetDevice::GetUlBandwidth ( ) const
Returns
the uplink bandwidth in RBs

Definition at line 172 of file lte-enb-net-device.cc.

References m_ulBandwidth.

uint16_t ns3::LteEnbNetDevice::GetUlEarfcn ( ) const
Returns
the uplink carrier frequency (EARFCN)

Definition at line 236 of file lte-enb-net-device.cc.

References m_ulEarfcn.

bool ns3::LteEnbNetDevice::Send ( Ptr< Packet packet,
const Address dest,
uint16_t  protocolNumber 
)
virtual
Parameters
packetpacket sent from above down to Network Device
destmac address of the destination (already resolved)
protocolNumberidentifies the type of payload contained in this packet. Used to call the right L3Protocol when the packet is received.

Called from higher layer to send packet into Network Device to the specified destination Address

Returns
whether the Send operation succeeded

Implements ns3::NetDevice.

Definition at line 261 of file lte-enb-net-device.cc.

References NS_ASSERT_MSG, and NS_LOG_FUNCTION.

void ns3::LteEnbNetDevice::SetDlBandwidth ( uint8_t  bw)
Parameters
bwthe downlink bandwidth in RBs

Definition at line 204 of file lte-enb-net-device.cc.

References m_dlBandwidth, and NS_FATAL_ERROR.

void ns3::LteEnbNetDevice::SetDlEarfcn ( uint16_t  earfcn)
Parameters
bwthe downlink carrier frequency (EARFCN)

Definition at line 230 of file lte-enb-net-device.cc.

References m_dlEarfcn.

void ns3::LteEnbNetDevice::SetUlBandwidth ( uint8_t  bw)
Parameters
bwthe uplink bandwidth in RBs

Definition at line 178 of file lte-enb-net-device.cc.

References m_ulBandwidth, and NS_FATAL_ERROR.

void ns3::LteEnbNetDevice::SetUlEarfcn ( uint16_t  earfcn)
Parameters
bwthe uplink carrier frequency (EARFCN)

Definition at line 242 of file lte-enb-net-device.cc.

References m_ulEarfcn.

void ns3::LteEnbNetDevice::UpdateConfig ( void  )
private

Several attributes (e.g., the bandwidth) are exported as attributes of the LteEnbNetDevice from a user perspective, but are actually used also in other modules as well (the RRC, the PHY, the scheduler...). This methods takes care of updating the configuration of all modules so that their copy of the attribute values is in sync with the one in the LteEnbNetDevice.

Definition at line 272 of file lte-enb-net-device.cc.

References m_cellId, m_dlBandwidth, m_dlEarfcn, m_ulBandwidth, m_ulEarfcn, and NS_LOG_FUNCTION.

Referenced by DoInitialize().

Member Data Documentation

uint16_t ns3::LteEnbNetDevice::m_cellId
private

Cell Identifer. Part of the CGI, see TS 29.274, section 8.21.1

Definition at line 149 of file lte-enb-net-device.h.

Referenced by GetCellId(), and UpdateConfig().

uint8_t ns3::LteEnbNetDevice::m_dlBandwidth
private

downlink bandwidth in RBs

Definition at line 151 of file lte-enb-net-device.h.

Referenced by GetDlBandwidth(), SetDlBandwidth(), and UpdateConfig().

uint16_t ns3::LteEnbNetDevice::m_dlEarfcn
private

downlink carrier frequency

Definition at line 154 of file lte-enb-net-device.h.

Referenced by GetDlEarfcn(), SetDlEarfcn(), and UpdateConfig().

uint8_t ns3::LteEnbNetDevice::m_ulBandwidth
private

uplink bandwidth in RBs

Definition at line 152 of file lte-enb-net-device.h.

Referenced by GetUlBandwidth(), SetUlBandwidth(), and UpdateConfig().

uint16_t ns3::LteEnbNetDevice::m_ulEarfcn
private

uplink carrier frequency

Definition at line 155 of file lte-enb-net-device.h.

Referenced by GetUlEarfcn(), SetUlEarfcn(), and UpdateConfig().


The documentation for this class was generated from the following files: