#include <tap-bridge.h>
Public Types | |
enum | Mode { ILLEGAL, CONFIGURE_LOCAL, USE_LOCAL, USE_BRIDGE } |
Public Member Functions | |
Ptr< NetDevice > | GetBridgedNetDevice (void) |
Get the bridged net device. | |
void | SetBridgedNetDevice (Ptr< NetDevice > bridgedDevice) |
Set the ns-3 net device to bridge. | |
void | Start (Time tStart) |
Set a start time for the device. | |
void | Stop (Time tStop) |
void | SetMode (TapBridge::Mode mode) |
TapBridge::Mode | GetMode (void) |
virtual void | SetIfIndex (const uint32_t index) |
virtual uint32_t | GetIfIndex (void) const |
virtual Ptr< Channel > | GetChannel (void) const |
virtual void | SetAddress (Address address) |
virtual Address | GetAddress (void) const |
virtual bool | SetMtu (const uint16_t mtu) |
virtual uint16_t | GetMtu (void) const |
virtual bool | IsLinkUp (void) const |
virtual void | SetLinkChangeCallback (Callback< void > callback) |
virtual bool | IsBroadcast (void) const |
virtual Address | GetBroadcast (void) const |
virtual bool | IsMulticast (void) const |
virtual Address | GetMulticast (Ipv4Address multicastGroup) const |
Make and return a MAC multicast address using the provided multicast group. | |
virtual bool | IsPointToPoint (void) const |
Return true if the net device is on a point-to-point link. | |
virtual bool | IsBridge (void) const |
Return true if the net device is acting as a bridge. | |
virtual bool | Send (Ptr< Packet > packet, const Address &dest, uint16_t protocolNumber) |
virtual bool | SendFrom (Ptr< Packet > packet, const Address &source, const Address &dest, uint16_t protocolNumber) |
virtual Ptr< Node > | GetNode (void) const |
virtual void | SetNode (Ptr< Node > node) |
virtual bool | NeedsArp (void) const |
virtual void | SetReceiveCallback (NetDevice::ReceiveCallback cb) |
virtual void | SetPromiscReceiveCallback (NetDevice::PromiscReceiveCallback cb) |
virtual bool | SupportsSendFrom () const |
virtual Address | GetMulticast (Ipv6Address addr) const |
Get the MAC multicast address corresponding to the IPv6 address provided. | |
Static Public Member Functions | |
static TypeId | GetTypeId (void) |
This method returns the TypeId associated to ns3::TapBridge. | |
Protected Member Functions | |
virtual void | DoDispose (void) |
The upshot is that the Tap Bridge appears to bridge a tap device on a Linux host in the "real world" to an ns-3 net device in the simulation and make is appear that a ns-3 net device is actually installed in the Linux host. In order to do this on the ns-3 side, we need a "ghost node" in the simulation to hold the bridged ns-3 net device and the TapBridge. This node should not actually do anything else in the simulation since its job is simply to make the net device appear in Linux. This is not just arbitrary policy, it is because:
Of course, if you understand all of the issues you can take control of your own destiny and do whatever you want -- we do not actively prevent you from using the ghost node for anything you decide. You will be able to perform typical ns-3 operations on the ghost node if you so desire. The internet stack, for example, must be there and functional on that node in order to participate in IP address assignment and global routing. However, as mentioned above, interfaces talking any Tap Bridge or associated bridged net devices will not work completely. If you understand exactly what you are doing, you can set up other interfaces and devices on the ghost node and use them; or take advantage of the operational send side of the bridged devices to create traffic generators. We generally recommend that you treat this node as a ghost of the Linux host and leave it to itself, though.
enum ns3::TapBridge::Mode |
virtual void ns3::TapBridge::DoDispose | ( | void | ) | [protected, 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.
Reimplemented from ns3::Object.
virtual Address ns3::TapBridge::GetAddress | ( | void | ) | const [virtual] |
Get the bridged net device.
The bridged net device is the ns-3 device to which this bridge is connected,
virtual Address ns3::TapBridge::GetBroadcast | ( | void | ) | const [virtual] |
Implements ns3::NetDevice.
Implements ns3::NetDevice.
virtual uint32_t ns3::TapBridge::GetIfIndex | ( | void | ) | const [virtual] |
TapBridge::Mode ns3::TapBridge::GetMode | ( | void | ) |
Get the operating mode of this device.
virtual uint16_t ns3::TapBridge::GetMtu | ( | void | ) | const [virtual] |
Implements ns3::NetDevice.
virtual Address ns3::TapBridge::GetMulticast | ( | Ipv6Address | addr | ) | const [virtual] |
Get the MAC multicast address corresponding to the IPv6 address provided.
addr | IPv6 address |
Implements ns3::NetDevice.
virtual Address ns3::TapBridge::GetMulticast | ( | Ipv4Address | multicastGroup | ) | const [virtual] |
Make and return a MAC multicast address using the provided multicast group.
RFC 1112 says that an Ipv4 host group address is mapped to an Ethernet multicast address by placing the low-order 23-bits of the IP address into the low-order 23 bits of the Ethernet multicast address 01-00-5E-00-00-00 (hex). Similar RFCs exist for Ipv6 and Eui64 mappings. This method performs the multicast address creation function appropriate to the underlying MAC address of the device. This MAC address is encapsulated in an abstract Address to avoid dependencies on the exact MAC address format.
A default imlementation of GetMulticast is provided, but this method simply NS_ASSERTS. In the case of net devices that do not support multicast, clients are expected to test NetDevice::IsMulticast and avoid attempting to map multicast packets. Subclasses of NetDevice that do support multicasting are expected to override this method and provide an implementation appropriate to the particular device.
multicastGroup | The IP address for the multicast group destination of the packet. |
Implements ns3::NetDevice.
Implements ns3::NetDevice.
static TypeId ns3::TapBridge::GetTypeId | ( | void | ) | [static] |
This method returns the TypeId associated to ns3::TapBridge.
This object is accessible through the following paths with Config::Set and Config::Connect:
Reimplemented from ns3::NetDevice.
virtual bool ns3::TapBridge::IsBridge | ( | void | ) | const [virtual] |
Return true if the net device is acting as a bridge.
Implements ns3::NetDevice.
virtual bool ns3::TapBridge::IsBroadcast | ( | void | ) | const [virtual] |
Implements ns3::NetDevice.
virtual bool ns3::TapBridge::IsLinkUp | ( | void | ) | const [virtual] |
virtual bool ns3::TapBridge::IsMulticast | ( | void | ) | const [virtual] |
virtual bool ns3::TapBridge::IsPointToPoint | ( | void | ) | const [virtual] |
Return true if the net device is on a point-to-point link.
Implements ns3::NetDevice.
virtual bool ns3::TapBridge::NeedsArp | ( | void | ) | const [virtual] |
Implements ns3::NetDevice.
virtual bool ns3::TapBridge::Send | ( | Ptr< Packet > | packet, | |
const Address & | dest, | |||
uint16_t | protocolNumber | |||
) | [virtual] |
packet | packet sent from above down to Network Device | |
dest | mac address of the destination (already resolved) | |
protocolNumber | identifies the type of payload contained in this packet. Used to call the right L3Protocol when the packet is received. |
Implements ns3::NetDevice.
virtual bool ns3::TapBridge::SendFrom | ( | Ptr< Packet > | packet, | |
const Address & | source, | |||
const Address & | dest, | |||
uint16_t | protocolNumber | |||
) | [virtual] |
packet | packet sent from above down to Network Device | |
source | source mac address (so called "MAC spoofing") | |
dest | mac address of the destination (already resolved) | |
protocolNumber | identifies the type of payload contained in this packet. Used to call the right L3Protocol when the packet is received. |
Implements ns3::NetDevice.
virtual void ns3::TapBridge::SetAddress | ( | Address | address | ) | [virtual] |
Set the address of this interface
Implements ns3::NetDevice.
Set the ns-3 net device to bridge.
This method tells the bridge which ns-3 net device it should use to connect the simulation side of the bridge.
virtual void ns3::TapBridge::SetIfIndex | ( | const uint32_t | index | ) | [virtual] |
virtual void ns3::TapBridge::SetLinkChangeCallback | ( | Callback< void > | callback | ) | [virtual] |
callback | the callback to invoke |
Implements ns3::NetDevice.
void ns3::TapBridge::SetMode | ( | TapBridge::Mode | mode | ) |
Set the operating mode of this device.
mode | The operating mode of this device. |
virtual bool ns3::TapBridge::SetMtu | ( | const uint16_t | mtu | ) | [virtual] |
mtu | MTU value, in bytes, to set for the device |
Implements ns3::NetDevice.
node | the node associated to this netdevice. |
Implements ns3::NetDevice.
virtual void ns3::TapBridge::SetPromiscReceiveCallback | ( | NetDevice::PromiscReceiveCallback | cb | ) | [virtual] |
cb | callback to invoke whenever a packet has been received in promiscuous mode and must be forwarded to the higher layers. |
Implements ns3::NetDevice.
virtual void ns3::TapBridge::SetReceiveCallback | ( | NetDevice::ReceiveCallback | cb | ) | [virtual] |
cb | callback to invoke whenever a packet has been received and must be forwarded to the higher layers. |
Implements ns3::NetDevice.
void ns3::TapBridge::Start | ( | Time | tStart | ) |
Set a start time for the device.
The tap bridge consumes a non-trivial amount of time to start. It starts up in the context of a scheduled event to ensure that all configuration has been completed before extracting the configuration (IP addresses, etc.) In order to allow a more reasonable start-up sequence than a thundering herd of devices, the time at which each device starts is also configurable bot via the Attribute system and via this call.
tStart | the start time |
void ns3::TapBridge::Stop | ( | Time | tStop | ) |
virtual bool ns3::TapBridge::SupportsSendFrom | ( | ) | const [virtual] |
Implements ns3::NetDevice.