Package: simu5g.nodes
Upf
compound moduleImplements 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.
Usage diagram
The following diagram shows usage relationships between types. Unresolved types are missing from the diagram.
Inheritance diagram
The following diagram shows inheritance relationships for this type. Unresolved types are missing from the diagram.
Used in compound modules
Name | Type | Description |
---|---|---|
MECHost | compound module |
This module represents a model of a Multi-access Edge Computing (MEC) host belonging to a MEC system, as specified by the ETSI GS MEC 003 specifications. It runs MEC applications within its VirtualisationInfrastructure and can provide a number of MEC services via the MEC platform. MEC applications can be created either dynamically by the MEC orchestrator or statically at the initialization of the simulation. The MEC host possesses a configurable number of computing resources (such as CPU speed, RAM, and storage) and keeps track of the utilization of these resources by the MEC applications via the VirtualisationInfrastructureManager. Moreover, this module includes a User Plane Function (UPF) that allows it to be connected with the 5G core network. |
Used in
Name | Type | Description |
---|---|---|
ExtClientServer_bgCells | network |
ExtClientServer_bgCells |
ExtClientServerExample | network |
ExtClientServerExample |
ExtMecAppExample | network | (no description) |
ExtServerExample | network |
ExtServerExample |
ExtUeAppExample | network | (no description) |
ExtUeAppMecAppExample | network | (no description) |
Extends
Name | Type | Description |
---|---|---|
NetworkLayerNodeBase | compound module | (no description) |
Parameters
Name | Type | Default value | Description |
---|---|---|---|
hasStatus | bool | false | |
osgModel | string | "" |
3D model for OSG visualization, no 3D model by default |
osgModelColor | string | "" |
tint color, no colorization by default |
canvasImage | string | "" |
image for canvas visualization, no image by default |
canvasImageColor | string | "" |
tint color, no colorization by default |
recordPcap | bool | false | |
numPcapRecorders | int | recordPcap ? 1 : 0 | |
numLoInterfaces | int | 1 | |
numWlanInterfaces | int | 0 | |
numEthInterfaces | int | 0 |
minimum number of ethernet interfaces |
numPppInterfaces | int | 0 |
minimum number of PPP interfaces |
numTunInterfaces | int | 0 | |
numVirtInterfaces | int | 0 | |
fcsMode | string | "declared" | |
hasIpv4 | bool | true | |
hasIpv6 | bool | false | |
hasGn | bool | false | |
forwarding | bool | true | |
multicastForwarding | bool | false | |
nodeType | string | "UPF" |
do NOT change! |
gateway | string | "" |
Properties
Name | Value | Description |
---|---|---|
networkNode | ||
labels | node | |
class | NodeBase | |
display | bgb=1348,1103;i=abstract/switch |
Gates
Name | Direction | Size | Description |
---|---|---|---|
radioIn [ ] | input | numWlanInterfaces | |
pppg [ ] | inout | numPppInterfaces | |
ethg [ ] | inout | numEthInterfaces | |
filterGate | inout |
this gate is used for the UPF connected to the external data network it must be left unconnected for intermediate UPFs |
Unassigned submodule parameters
Name | Type | Default value | Description |
---|---|---|---|
status.initialStatus | string | "UP" |
TODO @signal, @statistic |
pcapRecorder.verbose | bool | true |
whether to log packets on the module output |
pcapRecorder.pcapFile | string | "" |
the PCAP file to be written |
pcapRecorder.fileFormat | string | "pcapng" | |
pcapRecorder.snaplen | int | 65535 |
maximum number of bytes to record per packet |
pcapRecorder.dumpBadFrames | bool | true |
enable dump of frames with hasBitError |
pcapRecorder.moduleNamePatterns | string | "wlan[*] eth[*] ppp[*]" |
space-separated list of sibling module names to listen on |
pcapRecorder.sendingSignalNames | string | "packetSentToLower" |
space-separated list of outbound packet signals to subscribe to |
pcapRecorder.receivingSignalNames | string | "packetReceivedFromLower" |
space-separated list of inbound packet signals to subscribe to |
pcapRecorder.dumpProtocols | string | "ethernetmac ppp ieee80211mac" |
space-separated list of protocol names as defined in the Protocol class |
pcapRecorder.packetFilter | object | "*" |
which packets are considered, matches all packets by default |
pcapRecorder.helpers | string | "" |
usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper" |
pcapRecorder.alwaysFlush | bool | false |
flush the pcapFile after each write to ensure that all packets are captured in case of a crash |
pcapRecorder.displayStringTextFormat | string | "rec: %n pks" | |
interfaceTable.displayAddresses | bool | false |
whether to display IP addresses on links |
cb.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
cb.forwardServiceRegistration | bool | true | |
cb.forwardProtocolRegistration | bool | true | |
bl.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
bl.forwardServiceRegistration | bool | true | |
bl.forwardProtocolRegistration | bool | true | |
li.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
li.forwardServiceRegistration | bool | true | |
li.forwardProtocolRegistration | bool | true | |
eth.bitrate | double | ||
nl.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
nl.forwardServiceRegistration | bool | true | |
nl.forwardProtocolRegistration | bool | true | |
pppIf.pcapRecorder.verbose | bool | true |
whether to log packets on the module output |
pppIf.pcapRecorder.pcapFile | string | "" |
the PCAP file to be written |
pppIf.pcapRecorder.fileFormat | string | "pcapng" | |
pppIf.pcapRecorder.snaplen | int | 65535 |
maximum number of bytes to record per packet |
pppIf.pcapRecorder.dumpBadFrames | bool | true |
enable dump of frames with hasBitError |
pppIf.pcapRecorder.sendingSignalNames | string | "packetSentToLower" |
space-separated list of outbound packet signals to subscribe to |
pppIf.pcapRecorder.receivingSignalNames | string | "packetReceivedFromLower" |
space-separated list of inbound packet signals to subscribe to |
pppIf.pcapRecorder.dumpProtocols | string | "ethernetmac ppp ieee80211mac" |
space-separated list of protocol names as defined in the Protocol class |
pppIf.pcapRecorder.packetFilter | object | "*" |
which packets are considered, matches all packets by default |
pppIf.pcapRecorder.helpers | string | "" |
usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper" |
pppIf.pcapRecorder.alwaysFlush | bool | false |
flush the pcapFile after each write to ensure that all packets are captured in case of a crash |
pppIf.pcapRecorder.displayStringTextFormat | string | "rec: %n pks" | |
pppIf.ppp.interfaceTableModule | string |
The path to the InterfaceTable module |
|
pppIf.ppp.displayStringTextFormat | string | "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d" | |
pppIf.ppp.sendRawBytes | bool | false |
when true packets are serialized into a sequence of bytes before sending out |
pppIf.ppp.mtu | int | 4470B | |
pppIf.ppp.stopOperationExtraTime | double | -1s |
extra time after lifecycle stop operation finished |
pppIf.ppp.stopOperationTimeout | double | 2s |
timeout value for lifecycle stop operation |
udp.interfaceTableModule | string |
The path to the InterfaceTable module |
|
udp.icmpModule | string | "^.ipv4.icmp" | |
udp.icmpv6Module | string | "^.ipv6.icmpv6" | |
udp.crcMode | string | "declared" | |
udp.defaultMulticastLoop | bool | true | |
trafficFlowFilter.binderModule | string | "binder" | |
trafficFlowFilter.fastForwarding | bool | true | |
gtp_user.binderModule | string | "binder" | |
gtp_user.interfaceTableModule | string |
path to the InterfaceTable module |
|
gtp_user.ipOutInterface | string | "" |
optional: manual specification of outgoing interface for received IP |
gtp_user.localPort | int | 31 | |
gtp_user.tunnelPeerPort | int | 31 | |
tn.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
tn.forwardServiceRegistration | bool | true | |
tn.forwardProtocolRegistration | bool | true | |
at.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
at.forwardServiceRegistration | bool | true | |
at.forwardProtocolRegistration | bool | true |
Source code
// // 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; }File: src/nodes/Upf.ned