Files
unison/src/network/utils/simple-net-device.h
2014-09-06 07:08:49 +02:00

188 lines
5.9 KiB
C++

/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/*
* Copyright (c) 2008 INRIA
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation;
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
*/
#ifndef SIMPLE_NET_DEVICE_H
#define SIMPLE_NET_DEVICE_H
#include <stdint.h>
#include <string>
#include "ns3/traced-callback.h"
#include "ns3/net-device.h"
#include "ns3/queue.h"
#include "ns3/data-rate.h"
#include "ns3/data-rate.h"
#include "ns3/event-id.h"
#include "mac48-address.h"
namespace ns3 {
class SimpleChannel;
class Node;
class ErrorModel;
/**
* \ingroup netdevice
*
* This device assumes 48-bit mac addressing; there is also the possibility to
* add an ErrorModel if you want to force losses on the device.
*
* The device can be installed on a node through the SimpleNetDeviceHelper.
* In case of manual creation, the user is responsible for assigning an unique
* address to the device.
*
* By default the device is in Broadcast mode, with infinite bandwidth.
*
* \brief simple net device for simple things and testing
*/
class SimpleNetDevice : public NetDevice
{
public:
/**
* \brief Get the type ID.
* \return the object TypeId
*/
static TypeId GetTypeId (void);
SimpleNetDevice ();
/**
* Receive a packet from a connected SimpleChannel. The
* SimpleNetDevice receives packets from its connected channel
* and then forwards them by calling its rx callback method
*
* \param packet Packet received on the channel
* \param protocol protocol number
* \param to address packet should be sent to
* \param from address packet was sent from
*/
void Receive (Ptr<Packet> packet, uint16_t protocol, Mac48Address to, Mac48Address from);
/**
* Attach a channel to this net device. This will be the
* channel the net device sends on
*
* \param channel channel to assign to this net device
*
*/
void SetChannel (Ptr<SimpleChannel> channel);
/**
* Attach a queue to the SimpleNetDevice.
*
* \param queue Ptr to the new queue.
*/
void SetQueue (Ptr<Queue> queue);
/**
* Get a copy of the attached Queue.
*
* \returns Ptr to the queue.
*/
Ptr<Queue> GetQueue (void) const;
/**
* Attach a receive ErrorModel to the SimpleNetDevice.
*
* The SimpleNetDevice may optionally include an ErrorModel in
* the packet receive chain.
*
* \see ErrorModel
* \param em Ptr to the ErrorModel.
*/
void SetReceiveErrorModel (Ptr<ErrorModel> em);
// inherited from NetDevice base class.
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 AddLinkChangeCallback (Callback<void> callback);
virtual bool IsBroadcast (void) const;
virtual Address GetBroadcast (void) const;
virtual bool IsMulticast (void) const;
virtual Address GetMulticast (Ipv4Address multicastGroup) const;
virtual bool IsPointToPoint (void) const;
virtual bool IsBridge (void) const;
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 Address GetMulticast (Ipv6Address addr) const;
virtual void SetPromiscReceiveCallback (PromiscReceiveCallback cb);
virtual bool SupportsSendFrom (void) const;
protected:
virtual void DoDispose (void);
private:
Ptr<SimpleChannel> m_channel; //!< the channel the device is connected to
NetDevice::ReceiveCallback m_rxCallback; //!< Receive callback
NetDevice::PromiscReceiveCallback m_promiscCallback; //!< Promiscuous receive callback
Ptr<Node> m_node; //!< Node this netDevice is associated to
uint16_t m_mtu; //!< MTU
uint32_t m_ifIndex; //!< Interface index
Mac48Address m_address; //!< MAC address
Ptr<ErrorModel> m_receiveErrorModel; //!< Receive error model.
/**
* The trace source fired when the phy layer drops a packet it has received
* due to the error model being active. Although SimpleNetDevice doesn't
* really have a Phy model, we choose this trace source name for alignment
* with other trace sources.
*
* \see class CallBackTraceSource
*/
TracedCallback<Ptr<const Packet> > m_phyRxDropTrace;
/**
* The TransmitComplete method is used internally to finish the process
* of sending a packet out on the channel.
*/
void TransmitComplete (void);
bool m_linkUp; //!< Flag indicating whether or not the link is up
/**
* Flag indicating whether or not the NetDevice is a Point to Point model.
* Enabling this will disable Broadcast and Arp.
*/
bool m_pointToPointMode;
Ptr<Queue> m_queue; //!< The Queue for outgoing packets.
DataRate m_bps; //!< The device nominal Data rate. Zero means infinite
EventId TransmitCompleteEvent; //!< the Tx Complete event
/**
* List of callbacks to fire if the link changes state (up or down).
*/
TracedCallback<> m_linkChangeCallbacks;
};
} // namespace ns3
#endif /* SIMPLE_NET_DEVICE_H */