181 lines
6.6 KiB
C++
181 lines
6.6 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 INTERNET_STACK_HELPER_H
|
|
#define INTERNET_STACK_HELPER_H
|
|
|
|
#include "node-container.h"
|
|
#include "net-device-container.h"
|
|
#include "ns3/packet.h"
|
|
#include "ns3/ptr.h"
|
|
#include "ns3/object-factory.h"
|
|
|
|
namespace ns3 {
|
|
|
|
class Node;
|
|
class Ipv4RoutingHelper;
|
|
|
|
/**
|
|
* \brief aggregate IP/TCP/UDP functionality to existing Nodes.
|
|
*/
|
|
class InternetStackHelper
|
|
{
|
|
public:
|
|
/**
|
|
* Create a new InternetStackHelper which uses a mix of static routing
|
|
* and global routing by default. The static routing protocol
|
|
* (ns3::Ipv4StaticRouting) and the global routing protocol are
|
|
* stored in an ns3::Ipv4ListRouting protocol with priorities 0, and -10
|
|
* by default. If you wish to use different priorites and different
|
|
* routing protocols, you need to use an adhoc ns3::Ipv4RoutingHelper,
|
|
* such as ns3::OlsrHelper
|
|
*/
|
|
InternetStackHelper(void);
|
|
|
|
/**
|
|
* \param routing a new routing helper
|
|
*
|
|
* Set the routing helper to use during Install. The routing
|
|
* helper is really an object factory which is used to create
|
|
* an object of type ns3::Ipv4RoutingProtocol per node. This routing
|
|
* object is then associated to a single ns3::Ipv4 object through its
|
|
* ns3::Ipv4::SetRoutingProtocol.
|
|
*/
|
|
void SetRoutingHelper (const Ipv4RoutingHelper &routing);
|
|
|
|
/**
|
|
* Aggregate implementations of the ns3::Ipv4, ns3::Udp, and ns3::Tcp classes
|
|
* onto the provided node. This method will assert if called on a node that
|
|
* already has an Ipv4 object aggregated to it.
|
|
*
|
|
* \param nodeName The name of the node on which to install the stack.
|
|
*/
|
|
void Install (std::string nodeName) const;
|
|
|
|
/**
|
|
* Aggregate implementations of the ns3::Ipv4, ns3::Udp, and ns3::Tcp classes
|
|
* onto the provided node. This method will assert if called on a node that
|
|
* already has an Ipv4 object aggregated to it.
|
|
*
|
|
* \param node The node on which to install the stack.
|
|
*/
|
|
void Install (Ptr<Node> node) const;
|
|
|
|
/**
|
|
* For each node in the input container, aggregate implementations of the
|
|
* ns3::Ipv4, ns3::Udp, and, ns3::Tcp classes. The program will assert
|
|
* if this method is called on a container with a node that already has
|
|
* an Ipv4 object aggregated to it.
|
|
*
|
|
* \param c NodeContainer that holds the set of nodes on which to install the
|
|
* new stacks.
|
|
*/
|
|
void Install (NodeContainer c) const;
|
|
|
|
/**
|
|
* Aggregate ip, udp, and tcp stacks to all nodes in the simulation
|
|
*/
|
|
void InstallAll (void) const;
|
|
|
|
/**
|
|
* \brief set the Tcp stack which will not need any other parameter.
|
|
*
|
|
* This function sets up the tcp stack to the given TypeId. It should not be
|
|
* used for NSC stack setup because the nsc stack needs the Library attribute
|
|
* to be setup, please use instead the version that requires an attribute
|
|
* and a value. If you choose to use this function anyways to set nsc stack
|
|
* the default value for the linux library will be used: "liblinux2.6.26.so".
|
|
*
|
|
* \param tid the type id, typically it is set to "ns3::TcpL4Protocol"
|
|
*/
|
|
void SetTcp(std::string tid);
|
|
|
|
/**
|
|
* \brief This function is used to setup the Network Simulation Cradle stack with library value.
|
|
*
|
|
* Give the NSC stack a shared library file name to use when creating the
|
|
* stack implementation. The attr string is actually the attribute name to
|
|
* be setup and val is its value. The attribute is the stack implementation
|
|
* to be used and the value is the shared library name.
|
|
*
|
|
* \param tid The type id, for the case of nsc it would be "ns3::NscTcpL4Protocol"
|
|
* \param attr The attribute name that must be setup, for example "Library"
|
|
* \param val The attribute value, which will be in fact the shared library name (example:"liblinux2.6.26.so")
|
|
*/
|
|
void SetTcp (std::string tid, std::string attr, const AttributeValue &val);
|
|
|
|
/**
|
|
* \param os output stream
|
|
* \param n node container
|
|
*
|
|
* Enable ascii output on these drop traces, for each node in the NodeContainer..
|
|
* /NodeList/[i]/$ns3ArpL3Protocol/Drop
|
|
* /NodeList/[i]/$ns3Ipv4L3Protocol/Drop
|
|
*/
|
|
static void EnableAscii (std::ostream &os, NodeContainer n);
|
|
|
|
/**
|
|
* \param os output stream
|
|
*
|
|
* Enable ascii output on these drop traces, for all nodes.
|
|
* /NodeList/[i]/$ns3ArpL3Protocol/Drop
|
|
* /NodeList/[i]/$ns3Ipv4L3Protocol/Drop
|
|
*/
|
|
static void EnableAsciiAll (std::ostream &os);
|
|
|
|
/**
|
|
* Enable pcap output on each protocol instance which is of the
|
|
* ns3::Ipv4L3Protocol type. Both Tx and Rx events will be logged.
|
|
*
|
|
* \param filename filename prefix to use for pcap files.
|
|
*
|
|
* \warning If you perform multiple simulations in a single script,
|
|
* each iteration of the simulation will result in the trace files
|
|
* being overwritten. We don't attempt to anticipate what a user
|
|
* might actually want to do, so we leave it up to them. If you want
|
|
* to save any particular data, do so manually at inter-simulation
|
|
* time.
|
|
*/
|
|
static void EnablePcapAll (std::string filename);
|
|
|
|
private:
|
|
ObjectFactory m_tcpFactory;
|
|
const Ipv4RoutingHelper *m_routing;
|
|
static void CreateAndAggregateObjectFromTypeId (Ptr<Node> node, const std::string typeId);
|
|
static void Cleanup (void);
|
|
static void LogRxIp (std::string context, Ptr<const Packet> packet, uint32_t deviceId);
|
|
static void LogTxIp (std::string context, Ptr<const Packet> packet, uint32_t deviceId);
|
|
static Ptr<PcapWriter> GetStream (uint32_t nodeId, uint32_t interfaceId);
|
|
struct Trace {
|
|
uint32_t nodeId;
|
|
uint32_t interfaceId;
|
|
Ptr<PcapWriter> writer;
|
|
};
|
|
static void AsciiDropEvent (Ptr<AsciiWriter> writer, std::string path, Ptr<const Packet> packet);
|
|
static std::string m_pcapBaseFilename;
|
|
static uint32_t GetNodeIndex (std::string context);
|
|
static std::vector<Trace> m_traces;
|
|
static bool m_isInitialized;
|
|
};
|
|
|
|
} // namespace ns3
|
|
|
|
#endif /* INTERNET_STACK_HELPER_H */
|