A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
emu-epc-helper.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011-2019 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
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 * Authors:
18 * Jaume Nin <jnin@cttc.es>
19 * Nicola Baldo <nbaldo@cttc.es>
20 * Manuel Requena <manuel.requena@cttc.es>
21 */
22
23#ifndef EMU_EPC_HELPER_H
24#define EMU_EPC_HELPER_H
25
27
28namespace ns3
29{
30
31/**
32 * \ingroup lte
33 *
34 * \brief Create an EPC network using EmuFdNetDevice
35 *
36 * This Helper will create an EPC network topology comprising of a
37 * single node that implements both the SGW and PGW functionality, and
38 * an MME node. The S1-U, X2-U and X2-C interfaces are realized using
39 * EmuFdNetDevice; in particular, one device is used to send all the
40 * traffic related to these interfaces.
41 */
43{
44 public:
45 /**
46 * Constructor
47 */
49
50 /**
51 * Destructor
52 */
53 ~EmuEpcHelper() override;
54
55 // inherited from Object
56 /**
57 * Register this type.
58 * \return The object TypeId.
59 */
60 static TypeId GetTypeId();
61 TypeId GetInstanceTypeId() const override;
62 void DoDispose() override;
63
64 // inherited from EpcHelper
65 void AddEnb(Ptr<Node> enbNode,
66 Ptr<NetDevice> lteEnbNetDevice,
67 std::vector<uint16_t> cellIds) override;
68 void AddX2Interface(Ptr<Node> enbNode1, Ptr<Node> enbNode2) override;
69
70 private:
71 /**
72 * helper to assign addresses to S1-U NetDevices
73 */
75
76 /**
77 * Container for Ipv4Interfaces of the SGW
78 */
80
81 /**
82 * The name of the device used for the S1-U interface of the SGW
83 */
84 std::string m_sgwDeviceName;
85
86 /**
87 * The name of the device used for the S1-U interface of the eNB
88 */
89 std::string m_enbDeviceName;
90
91 /**
92 * MAC address used for the SGW
93 */
94 std::string m_sgwMacAddress;
95
96 /**
97 * First 5 bytes of the Enb MAC address base
98 */
100};
101
102} // namespace ns3
103
104#endif // EMU_EPC_HELPER_H
Create an EPC network using EmuFdNetDevice.
TypeId GetInstanceTypeId() const override
Get the most derived TypeId for this Object.
EmuEpcHelper()
Constructor.
static TypeId GetTypeId()
Register this type.
~EmuEpcHelper() override
Destructor.
Ipv4AddressHelper m_epcIpv4AddressHelper
helper to assign addresses to S1-U NetDevices
std::string m_enbMacAddressBase
First 5 bytes of the Enb MAC address base.
void DoDispose() override
Destructor implementation.
std::string m_enbDeviceName
The name of the device used for the S1-U interface of the eNB.
std::string m_sgwDeviceName
The name of the device used for the S1-U interface of the SGW.
std::string m_sgwMacAddress
MAC address used for the SGW.
void AddX2Interface(Ptr< Node > enbNode1, Ptr< Node > enbNode2) override
Add an X2 interface between two eNB.
Ipv4InterfaceContainer m_sgwIpIfaces
Container for Ipv4Interfaces of the SGW.
void AddEnb(Ptr< Node > enbNode, Ptr< NetDevice > lteEnbNetDevice, std::vector< uint16_t > cellIds) override
Add an eNB to the EPC.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Create an EPC network with PointToPoint links between the core network nodes.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.