A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
netmap-net-device-helper.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2017 Universita' degli Studi di Napoli Federico II
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Pasquale Imputato <p.imputato@gmail.com>
18 */
19
20#ifndef NETMAP_NET_DEVICE_HELPER_H
21#define NETMAP_NET_DEVICE_HELPER_H
22
24
25#include "ns3/attribute.h"
26#include "ns3/fd-net-device.h"
27#include "ns3/net-device-container.h"
28#include "ns3/netmap-net-device.h"
29#include "ns3/node-container.h"
30#include "ns3/object-factory.h"
31
32#include <string>
33
34namespace ns3
35{
36
37class NetmapNetDevice;
38
39/**
40 * \ingroup fd-net-device
41 * \brief build a set of FdNetDevice objects attached to a physical network
42 * interface
43 *
44 */
46{
47 public:
49
51 {
52 }
53
54 /**
55 * \brief Get the device name of this device.
56 * \returns The device name of this device.
57 */
58 std::string GetDeviceName();
59
60 /**
61 * \brief Set the device name of this device.
62 * \param deviceName The device name of this device.
63 */
64 void SetDeviceName(std::string deviceName);
65
66 protected:
67 /**
68 * \brief This method creates an ns3::FdNetDevice attached to a physical network
69 * interface
70 * \param node The node to install the device in
71 * \returns A container holding the added net device.
72 */
74
75 /**
76 * \brief Sets device flags and MTU.
77 * \param device the FdNetDevice
78 */
79 virtual void SetDeviceAttributes(Ptr<FdNetDevice> device) const;
80
81 /**
82 * \brief Call out to a separate process running as suid root in order to get a raw
83 * socket. We do this to avoid having the entire simulation running as root.
84 * \return the rawSocket number
85 */
86 virtual int CreateFileDescriptor() const;
87
88 /**
89 * \brief Switch the fd in netmap mode.
90 * \param fd the file descriptor
91 * \param device the NetmapNetDevice
92 */
93 void SwitchInNetmapMode(int fd, Ptr<NetmapNetDevice> device) const;
94
95 std::string m_deviceName; //!< The unix/linux name of the underlying device (e.g., eth0)
96};
97
98} // namespace ns3
99
100#endif /* NETMAP_NET_DEVICE_HELPER_H */
build a set of FdNetDevice objects Normally we eschew multiple inheritance, however,...
build a set of FdNetDevice objects attached to a physical network interface
Ptr< NetDevice > InstallPriv(Ptr< Node > node) const
This method creates an ns3::FdNetDevice attached to a physical network interface.
virtual int CreateFileDescriptor() const
Call out to a separate process running as suid root in order to get a raw socket.
void SetDeviceName(std::string deviceName)
Set the device name of this device.
std::string m_deviceName
The unix/linux name of the underlying device (e.g., eth0)
void SwitchInNetmapMode(int fd, Ptr< NetmapNetDevice > device) const
Switch the fd in netmap mode.
std::string GetDeviceName()
Get the device name of this device.
virtual void SetDeviceAttributes(Ptr< FdNetDevice > device) const
Sets device flags and MTU.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
Every class exported by the ns3 library is enclosed in the ns3 namespace.