NED File src/nodes/Upf.ned
Name | Type | Description |
---|---|---|
Upf | compound module |
Implements a 5G Core User Plane Function (UPF) module. |
Source code
// // Simu5G // // Authors: Giovanni Nardini, Giovanni Stea, Antonio Virdis (University of Pisa) // // This file is part of a software released under the license included in file // "license.pdf". Please read LICENSE and README files before using it. // The above files and the present reference are part of the software itself, // and cannot be removed from it. // package simu5g.nodes; import inet.common.MessageDispatcher; import inet.linklayer.ppp.PppInterface; import inet.transportlayer.udp.Udp; import inet.node.base.NetworkLayerNodeBase; import simu5g.corenetwork.gtp.GtpUser; import simu5g.corenetwork.trafficFlowFilter.TrafficFlowFilter; // // Implements a 5G Core User Plane Function (UPF) module. // // The UPF is responsible for packet routing and forwarding, packet inspection, and (de)tunneling according to GTP. // The core network can contain multiple UPFs. Intermediate UPFs, which are not connected to an external Data Network, // act like IP routers in the current version. // This module allows the connection of mobile terminals to external data networks or other 5G network elements through GTP tunneling. // module Upf extends NetworkLayerNodeBase { parameters: @display("bgb=1348,1103;i=abstract/switch"); @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[submodules]; string nodeType = default("UPF"); // do NOT change! string gateway = default(""); forwarding = default(true); multicastForwarding = default(false); gates: // this gate is used for the UPF connected to the external data network // it must be left unconnected for intermediate UPFs inout filterGate @loose @labels(PppFrame-conn); submodules: pppIf: PppInterface { parameters: @display("p=1150,1000"); } udp: Udp { parameters: @display("p=375,200"); } trafficFlowFilter: TrafficFlowFilter { parameters: @display("p=1250,80"); ownerType = parent.nodeType; } gtp_user: GtpUser { parameters: @display("p=935,80"); gateway = parent.gateway; } tn: MessageDispatcher { parameters: @display("p=750,300;b=1000,5,,,,1"); } at: MessageDispatcher { parameters: @display("p=750,146;b=1000,5,,,,1"); } connections: gtp_user.socketOut --> at.in++; gtp_user.socketIn <-- at.out++; pppIf.upperLayerOut --> trafficFlowFilter.internetFilterGateIn; pppIf.upperLayerIn <-- gtp_user.pppGate; trafficFlowFilter.gtpUserGateOut --> gtp_user.trafficFlowFilterGate; // at dispatcher to transport layer connections at.out++ --> udp.appIn; at.in++ <-- udp.appOut; // transport layer to tn dispatcher connections udp.ipOut --> tn.in++; udp.ipIn <-- tn.out++; // tn dispatcher to network layer connections tn.out++ --> ipv4.transportIn if hasIpv4; tn.in++ <-- ipv4.transportOut if hasIpv4; tn.out++ --> ipv6.transportIn if hasIpv6; tn.in++ <-- ipv6.transportOut if hasIpv6; tn.out++ --> generic.transportIn if hasGn; tn.in++ <-- generic.transportOut if hasGn; tn.out++ --> nl.in++; tn.in++ <-- nl.out++; pppIf.phys <--> filterGate; }