Package: simu5g.nodes
PgwStandard
compound moduleThis module implements a simplified model of the EPC PDN Gateway (P-GW) of a 4G LTE network. It serves as the entry point to the core network of an LTE network, thus bridging it to the rest of the Internet. Packets arriving from the Internet are tunneled to the appropriate next hop in the core network (e.g., the eNodeB that will transmit the packet to the destination User Equipment through the radio access network) using the GPRS Tunneling Protocol (GTP). Conversely, packets received from the core network are detunneled and sent to the Internet (e.g., towards a remote server). To accomplish this, it utilizes a GtpUser module that handles GTP (de)tunneling, along with the TrafficFlowFilter module, which classifies incoming packets.
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.
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 | "PGW" |
Properties
Name | Value | Description |
---|---|---|
networkNode | ||
labels | node | |
class | NodeBase | |
display | bgb=1350,750;i=device/mainframe |
Gates
Name | Direction | Size | Description |
---|---|---|---|
radioIn [ ] | input | numWlanInterfaces | |
pppg [ ] | inout | numPppInterfaces | |
ethg [ ] | inout | numEthInterfaces | |
filterGate | inout |
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 | |
gtp_user.gateway | string | "" |
optional |
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
// // This module implements a simplified model of the EPC PDN Gateway (P-GW) of a 4G LTE network. // It serves as the entry point to the core network of an LTE network, thus bridging it to the rest // of the Internet. Packets arriving from the Internet are tunneled to the appropriate next hop in // the core network (e.g., the ~eNodeB that will transmit the packet to the destination User Equipment // through the radio access network) using the GPRS Tunneling Protocol (GTP). Conversely, packets // received from the core network are detunneled and sent to the Internet (e.g., towards a remote server). // To accomplish this, it utilizes a ~GtpUser module that handles GTP (de)tunneling, along with the // ~TrafficFlowFilter module, which classifies incoming packets. // module PgwStandard extends NetworkLayerNodeBase { parameters: @display("bgb=1350,750;i=device/mainframe"); @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 = "PGW"; forwarding = default(true); multicastForwarding = default(false); // numPppInterfaces = 1; gates: inout filterGate @labels(PppFrame-conn); submodules: pppIf: PppInterface { parameters: @display("p=1150,525"); } udp: Udp { parameters: @display("p=330,206"); } trafficFlowFilter: TrafficFlowFilter { parameters: @display("p=675,80"); ownerType = parent.nodeType; } gtp_user: GtpUser { parameters: @display("p=525,80"); } 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/PgwStandard.ned