doc/howtos/howtos-net-device.h
author Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
Tue, 02 Sep 2008 10:12:14 -0700
changeset 3576 f6abfdf47163
parent 3315 85d6b10511fe
permissions -rw-r--r--
bug 303: return value should not be const
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3313
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/*!
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
  \page net-device How to create a new OSI layer 1 + 2 implementation ?
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     3
  \anchor howtos-net-device
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     4
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
  <b>Question:</b> How do I integrate a new OSI layer 1 + 2 implementation ?
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
  <b>Answer:</b> The OSI layers 1 and 2 are represented by the ns3::NetDevice
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
  and ns3::Channel classes. To plug transparently in ns-3, a new layer 1+2 model
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
  thus simply needs to provide two new subclasses of these two base classes.
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
  To make that subclassing process easy, two skeleton classes are provided in
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
  the src/node directory: simple-net-device.h (ns3::SimpleNetDevice) and 
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
  simple-channel.h (ns3::SimpleChannel) implement a broadcast passthru medium 
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
  using 48bit MAC addresses without any kind of MAC access algorithm or PHY 
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
  layer modeling.
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
  The ns3::SimpleChannel class is really very simple: it provides
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
  an implementation for the ns3::Channel::GetNDevices and ns3::Channel::GetDevice
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
  methods defined in the Channel base class and, then defines the channel-specific
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    20
  send and add methods:
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    21
- The Add method is used by SimpleNetDevice::SetChannel to register a new 
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
  SimpleNetDevice with its associated channel.
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    23
- The Send method is used by SimpleNetDevice::Send to send a packet over the
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    24
  broadcast medium and ensure that it gets delivered to all associated devices
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    25
  (except the sender).
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    26
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    27
\code
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    28
class SimpleChannel : public Channel
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    29
{
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    30
public:
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    31
  static TypeId GetTypeId (void);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    32
  SimpleChannel ();
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    33
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    34
  void Send (Ptr<Packet> p, uint16_t protocol, Mac48Address to, Mac48Address from,
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    35
	     Ptr<SimpleNetDevice> sender);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    36
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    37
  void Add (Ptr<SimpleNetDevice> device);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    38
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    39
  // inherited from ns3::Channel
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    40
  virtual uint32_t GetNDevices (void) const;
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    41
  virtual Ptr<NetDevice> GetDevice (uint32_t i) const;
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    42
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    43
private:
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    44
  std::vector<Ptr<SimpleNetDevice> > m_devices;
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    45
};
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    46
\endcode
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    47
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    48
The SimpleNetDevice class is also trivial since it implements no special
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    49
MAC-layer processing:
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    50
\code
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    51
class SimpleNetDevice : public NetDevice
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    52
{
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    53
public:
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    54
  static TypeId GetTypeId (void);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    55
  SimpleNetDevice ();
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    56
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    57
  void Receive (Ptr<Packet> packet, uint16_t protocol, Mac48Address to, Mac48Address from);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    58
  void SetChannel (Ptr<SimpleChannel> channel);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    59
  void SetAddress (Mac48Address address);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    60
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    61
  // inherited from NetDevice base class.
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    62
  virtual void SetName(const std::string name);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    63
  ...
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    64
};
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    65
\endcode
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    66
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    67
The code below illustrates how the three model-specific methods defined above are
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    68
implemented:
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    69
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    70
\code
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    71
void 
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    72
SimpleNetDevice::Receive (Ptr<Packet> packet, uint16_t protocol, 
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    73
			  Mac48Address to, Mac48Address from)
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    74
{
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    75
  if (to == m_address || to == Mac48Address::GetBroadcast ())
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    76
    {
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    77
      m_rxCallback (this, packet, protocol, from);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    78
    }
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    79
}
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    80
void 
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    81
SimpleNetDevice::SetChannel (Ptr<SimpleChannel> channel)
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    82
{
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    83
  m_channel = channel;
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    84
  m_channel->Add (this);
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    85
}
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    86
void 
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    87
SimpleNetDevice::SetAddress (Mac48Address address)
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    88
{
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    89
  m_address = address;
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    90
}
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    91
\endcode
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    92
3315
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
    93
Building a topology with such a device is then a matter of
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
    94
instanciating a set of SimpleNetDevice objects connected on a shared
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
    95
SimpleChannel:
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
    96
\code
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
    97
NodeContainer nodes;
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
    98
nodes.Create (10);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
    99
Ptr<SimpleChannel> channel = CreateObject<SimpleChannel> ();
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   100
for (uint32_t i = 0; i < nodes.GetN (); ++i)
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   101
  {
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   102
    CreateSimpleDevice (nodes.Get (i), channel);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   103
  }
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   104
\endcode
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   105
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   106
With the following CreateSimpleDevice function:
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   107
\code
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   108
static Ptr<SimpleNetDevice>
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   109
CreateSimpleDevice (Ptr<Node> node, Ptr<SimpleChannel> channel)
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   110
{
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   111
  Ptr<SimpleNetDevice> device = CreateObject<SimpleNetDevice> ();
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   112
  device->SetAddress (Mac48Address:Allocate ());
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   113
  device->SetChannel (channel);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   114
  node->AddDevice (device);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   115
  return device;
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   116
}
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   117
\endcode
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   118
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   119
Of course, ultimately, you need to provide a helper class for this new device and channel
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   120
to save each user from having to re-implement their own CreateSimpleDevice helper 
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   121
function:
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   122
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   123
\code
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   124
class SimpleHelper
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   125
{
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   126
public:
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   127
  NetDeviceContainer Install (NodeContainer nodes, Ptr<SimpleChannel> channel);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   128
  NetDeviceContainer Install (NodeContainer nodes);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   129
};
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   130
\endcode
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   131
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   132
with the following straightforward implementation, inspired by the CreateSimpleDevice 
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   133
function defined above:
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   134
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   135
\code
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   136
NetDeviceContainer
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   137
SimpleHelper::Install (NodeContainer nodes, Ptr<SimpleChannel> channel)
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   138
{
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   139
  NetDeviceContainer devices;
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   140
  for (NodeContainer::Iterator i = nodes.Begin (); i != nodes.End (); ++i)
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   141
    {
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   142
      Ptr<SimpleNetDevice> dev = CreateObject<SimpleNetDevice> ();
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   143
      dev->SetAddress (Mac48Address::Allocate ());
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   144
      dev->SetChannel (channel);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   145
      (*i)->AddDevice (dev);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   146
      devices.Add (dev);
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   147
    }
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   148
  return devices;
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   149
}
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   150
NetDeviceContainer
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   151
SimpleHelper::Install (NodeContainer nodes)
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   152
{
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   153
  return Install (nodes, CreateObject<SimpleChannel> ());
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   154
}
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   155
\endcode
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   156
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   157
Of course, at some point, this device helper class should also contain a couple of 
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   158
ascii and pcap tracing helper functions but, since the default SimpleNetDevice
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   159
class we used as an example here does not report any trace event, it would
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   160
be of little use.
85d6b10511fe add helper code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3313
diff changeset
   161
3313
9410e0ff6a1c a very simple howto for implementing NetDevice/Channel subclasses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   162
*/