NED File src/nodes/eNodeB.ned
Name | Type | Description |
---|---|---|
eNodeB | compound module |
This module models an evolved Node B (eNB) of a 4G LTE network. It is a specialized device equipped with a Network Interface Card (NIC) that enables communication with the Ue devices connected to it. It serves as an access point that routes packets between the UEs and the 4G Core Network. Packets arriving from the UEs are tunneled to the appropriate next hop in the core network (e.g., the PDN Gateway, PGW) using the GPRS Tunneling Protocol (GTP). Conversely, packets received from the core network are detunneled and sent to the appropriate destination UE. In addition to the 4G NIC, this compound module includes a configurable number of wired interfaces to connect with routers of the core network or directly to the PgwStandard module, which serves as the IP module to perform forwarding, and the GtpUser module that handles GTP (de)tunneling. The latter utilizes the TrafficFlowFilter module to classify incoming packets and determine the next hop. Furthermore, it features a configurable number of LteX2App modules to facilitate peer-to-peer communications with other eNodeBs within the same LTE network. |
Source code
// // Simu5G // // This file is part of a software released under the license included in file // "license.pdf". This license can be also found at http://www.ltesimulator.com/ // The above file and the present reference are part of the software itself, // and cannot be removed from it. // package simu5g.nodes; import inet.applications.contract.IApp; import inet.common.MessageDispatcher; import inet.linklayer.ppp.PppInterface; import inet.mobility.static.StationaryMobility; import inet.networklayer.common.InterfaceTable; import inet.networklayer.contract.INetworkLayer; import inet.transportlayer.sctp.Sctp; import inet.transportlayer.tcp.Tcp; import inet.transportlayer.udp.Udp; import simu5g.common.cellInfo.CellInfo; import simu5g.corenetwork.gtp.GtpUser; import simu5g.corenetwork.gtp.GtpUserX2; import simu5g.corenetwork.statsCollector.IStatsCollector; import simu5g.corenetwork.trafficFlowFilter.TrafficFlowFilter; import simu5g.stack.ICellularNic; import simu5g.x2.LteX2App; // // This module models an evolved Node B (eNB) of a 4G LTE network. It is a specialized device equipped // with a Network Interface Card (NIC) that enables communication with the ~Ue devices connected // to it. It serves as an access point that routes packets between the UEs and the 4G Core Network. // Packets arriving from the UEs are tunneled to the appropriate next hop in the core network (e.g., // the PDN Gateway, PGW) using the GPRS Tunneling Protocol (GTP). Conversely, packets // received from the core network are detunneled and sent to the appropriate destination UE. // In addition to the 4G NIC, this compound module includes a configurable number of wired interfaces // to connect with routers of the core network or directly to the ~PgwStandard module, which serves // as the IP module to perform forwarding, and the ~GtpUser module that handles GTP (de)tunneling. The latter // utilizes the ~TrafficFlowFilter module to classify incoming packets and determine the next hop. // Furthermore, it features a configurable number of ~LteX2App modules to facilitate peer-to-peer communications with // other eNodeBs within the same LTE network. // module eNodeB { parameters: @networkNode; @labels(node,ethernet-node,wireless-node); @display("i=device/antennatower;bgb=1260,600"); @figure[applicationLayer](type=rectangle; pos=250,6; size=1000,130; lineColor=#808080; cornerRadius=5; fillColor=#ffff00; fillOpacity=0.1); @figure[applicationLayer.title](type=text; pos=1245,11; anchor=ne; text="application layer"); @figure[transportLayer](type=rectangle; pos=250,156; size=1000,130; fillColor=#ff0000; lineColor=#808080; cornerRadius=5; fillOpacity=0.1); @figure[transportLayer.title](type=text; pos=1245,161; anchor=ne; text="transport layer"); @figure[networkLayer](type=rectangle; pos=250,306; size=1000,130; fillColor=#00ff00; lineColor=#808080; cornerRadius=5; fillOpacity=0.1); @figure[networkLayer.title](type=text; pos=1245,311; anchor=ne; text="network layer"); @figure[linkLayer](type=rectangle; pos=250,456; size=1000,130; fillColor=#0000ff; lineColor=#808080; cornerRadius=5; fillOpacity=0.1); @figure[linkLayer.title](type=text; pos=1245,461; anchor=ne; text="link layer"); @figure[submodules]; @statistic[posX](source="xCoord(mobilityPos(mobilityStateChanged))"; record=vector?); @statistic[posY](source="yCoord(mobilityPos(mobilityStateChanged))"; record=vector?); //# Node specs string nodeType = default("ENODEB"); // DO NOT CHANGE string gateway = default("pgw"); int masterId @mutable = default(0); // ID of the master eNodeB. Used in case of Dual Connectivity int macNodeId @mutable = default(0); // TODO: this is not a real parameter int macCellId @mutable = default(0); // TODO: this is not a real parameter double txPower @unit(mw) = default(100mw); //# Network Layer specs bool hasIpv4 = default(true); bool hasIpv6 = default(false); *.interfaceTableModule = default(absPath(".interfaceTable")); *.routingTableModule = default("^.ipv4.routingTable"); *.forwarding = true; *.multicastForwarding = false; **.cellInfoModule = default(absPath(".cellInfo")); //# Apps int numApps = default(0); // no of apps. int numX2Apps = default(0); // no of X2 apps. Specify the app types in INI file with x2App[0..1].typename="X2AppClient" syntax //# Transport layer bool hasUdp = true; bool hasTcp = default(firstAvailableOrEmpty("Tcp", "TcpLwip", "TcpNsc") != ""); bool hasSctp = true; //# MEC support string mecHost = default(""); // symbolic name of the connected MEHost in the Network //# @author Alessandro Noferi bool hasRNISupport = default(false); //# use it in case of emulation string extMeAppsAddress = default(""); // Address of the external MeApp IP/mask //# Plmn params (used by RNI Service in EnodeBStatsCollector) string mcc = default("001"); // Test network string mnc = default("01"); // Test network gates: inout ppp @loose; // connection to the Core Network input radioIn @directIn; // connection to the radio interface inout x2[]; // connection to the X2 interface //# MEC support inout pppMEHost @loose; // connection to the GtpEndpoint module inside MEHost submodules: interfaceTable: InterfaceTable { parameters: @display("p=110,158;is=s"); } mobility: StationaryMobility { parameters: @display("p=110,343;is=s"); } cellInfo: CellInfo { parameters: @display("p=110,244;is=s"); } collector: <default("BaseStationStatsCollector")> like IStatsCollector if hasRNISupport { @display("p=50,275;is=s"); } //# //# cellularNic modules //# cellularNic: <default("LteNicEnb")> like ICellularNic { parameters: @display("p=433,520"); nodeType = parent.nodeType; } pppIf: PppInterface { parameters: @display("p=824,519"); } x2ppp[sizeof(x2)]: PppInterface { parameters: @display("p=980,519"); } //# //# Mec interface //# pppMEHostIf: PppInterface { @display("p=657,519"); } //# //# Network layer module //# ipv4: <default("Ipv4NetworkLayer")> like INetworkLayer if hasIpv4 { parameters: @display("p=494,372;q=queue"); } ipv6: <default("Ipv6NetworkLayer")> like INetworkLayer if hasIpv6 { parameters: @display("p=657,374;q=queue"); } //# //# Transport layer modules and corresponding application modules //# // =============== Udp ============== // app[numApps]: <> like IApp { parameters: @display("p=748,75,row,140"); } udp: Udp { parameters: @display("p=682,212"); } tcp: Tcp if hasTcp { parameters: @display("p=963,212"); } // =============== X2AP ============== // x2App[numX2Apps]: LteX2App { parameters: @display("p=371,75,row"); } sctp: Sctp { parameters: @display("p=494,211"); } // message dispatcher for SAP between application and transport layer at: MessageDispatcher { parameters: @display("p=750,146;b=1000,5,,,,1"); } // message dispatcher for SAP between transport and network layer tn: MessageDispatcher { parameters: @display("p=750,300;b=1000,5,,,,1"); } // message dispatcher for SAP to link layer nl: MessageDispatcher { parameters: @display("p=750,446;b=1000,5,,,,1"); } //# //# Modules for connecting to the core network and X2 //# trafficFlowFilter: TrafficFlowFilter { parameters: @display("p=1172,372"); ownerType = parent.nodeType; } gtpUser: GtpUser { parameters: @display("p=1041,372"); ipOutInterface = "cellular"; gateway = parent.gateway; } gtpUserX2: GtpUserX2 { parameters: @display("p=900,372"); } connections allowunconnected: //# //# LTE stack to PHY and network layer //# cellularNic.radioIn <-- radioIn; //# //# Ppp interface to network layer connections //# pppIf.phys <--> ppp; pppIf.upperLayerOut --> nl.in++; pppIf.upperLayerIn <-- nl.out++; //# //# X2 interface to network layer connections //# for i=0..sizeof(x2)-1 { x2ppp[i].phys <--> x2[i]; x2ppp[i].upperLayerOut --> tn.in++; x2ppp[i].upperLayerIn <-- tn.out++; } //# //# Connections to the core network //# nl.in++ <-- gtpUser.pppGate; trafficFlowFilter.gtpUserGateOut --> gtpUser.trafficFlowFilterGate; trafficFlowFilter.internetFilterGateIn <-- nl.out++; gtpUser.socketOut --> at.in++; gtpUser.socketIn <-- at.out++; //# GTPUserX2 connections gtpUserX2.lteStackOut --> cellularNic.x2$i++; gtpUserX2.lteStackIn <-- cellularNic.x2$o++; gtpUserX2.socketOut --> at.in++; gtpUserX2.socketIn <-- at.out++; //# X2 apps connections for i=0..numX2Apps-1 { x2App[i].sctpOut[0] --> at.in++; x2App[i].sctpIn[0] <-- at.out++; x2App[i].sctpOut[1] --> at.in++; x2App[i].sctpIn[1] <-- at.out++; x2App[i].x2ManagerIn <-- cellularNic.x2$o++; x2App[i].x2ManagerOut --> cellularNic.x2$i++; } //# //# Apps to transport layer connections //# for i=0..numApps-1 { app[i].socketOut --> at.in++; app[i].socketIn <-- at.out++; } at.out++ --> udp.appIn if hasUdp; at.in++ <-- udp.appOut if hasUdp; at.out++ --> tcp.appIn if hasTcp; at.in++ <-- tcp.appOut if hasTcp; at.out++ --> sctp.appIn if hasSctp; at.in++ <-- sctp.appOut if hasSctp; //# //# Transport layer to network layer connections //# udp.ipOut --> tn.in++ if hasUdp; udp.ipIn <-- tn.out++ if hasUdp; tcp.ipOut --> tn.in++ if hasTcp; tcp.ipIn <-- tn.out++ if hasTcp; sctp.ipOut --> tn.in++ if hasSctp; tn.out++ --> sctp.ipIn if hasSctp; ipv4.ifIn <-- nl.out++ if hasIpv4; ipv4.ifOut --> nl.in++ if hasIpv4; ipv4.transportIn <-- tn.out++ if hasIpv4; ipv4.transportOut --> tn.in++ if hasIpv4; ipv6.ifIn <-- nl.out++ if hasIpv6; ipv6.ifOut --> nl.in++ if hasIpv6; ipv6.transportIn <-- tn.out++ if hasIpv6; ipv6.transportOut --> tn.in++ if hasIpv6; tn.out++ --> nl.in++; tn.in++ <-- nl.out++; at.out++ --> tn.in++; at.in++ <-- tn.out++; cellularNic.upperLayerIn <-- nl.out++; cellularNic.upperLayerOut --> nl.in++; //# //# MEC support //# pppMEHostIf.upperLayerIn <-- nl.out++; pppMEHostIf.upperLayerOut --> nl.in++; pppMEHost <--> pppMEHostIf.phys; }