ExtUeAppMecAppExample

Package: simu5g.emulation.mec.extUeAppMecApp

ExtUeAppMecAppExample

network

(no description)

routingRecorder : RoutingTableRecorder

Records changes in the routing tables (~Ipv4RoutingTable) and interface tables (~InterfaceTable) of...

Source:
routingRecorder: RoutingTableRecorder {
    @display("p=690,104;is=s");
} configurator : Ipv4NetworkConfigurator

This module assigns IPv4 addresses and sets up static routing for an IPv4 network.

Source:
configurator: Ipv4NetworkConfigurator {
    @display("p=556,34");
} channelControl : LteChannelControl

Utility module that records the position of each LTE radio module in the network.

Source:
channelControl: LteChannelControl {
    @display("p=690,24;is=s");
} binder : Binder

Binder module

Source:
binder: Binder {
    @display("p=474,34;is=s");
} carrierAggregation : CarrierAggregation

This module implements the Carrier Aggregation (CA) functionality used at the Medium Access Control...

Source:
carrierAggregation: CarrierAggregation {
    @display("p=368,34;is=s");
} upf : Upf

Implements a 5G Core User Plane Function (UPF) module.

Source:
upf: Upf {
    @display("p=420,259");
} iUpf : Upf

Implements a 5G Core User Plane Function (UPF) module.

Source:
iUpf: Upf {
    @display("p=277,259");
} gNodeB1 : gNodeB

This module implements a gNodeB for a 5G LTE network.

Source:
gNodeB1: gNodeB {
    @display("p=137,260;is=vl");
} mecHost1 : MECHost

This module represents a model of a Multi-access Edge Computing (MEC) host belonging to a MEC...

Source:
mecHost1: MECHost {
    @display("p=277,158;is=l");
} mecOrchestrator : MecOrchestrator

This module models the functionalities of the MEC orchestrator within a Multi-access Edge Computing...

Source:
mecOrchestrator: MecOrchestrator {
    @display("p=520,158;is=l");
} ualcmp : UALCMP

This module represents a host performing the functions of the User Application Lifecycle Management...

Source:
ualcmp: UALCMP {
    @display("p=420,157;i=device/smallrouter");
} ue : NRUe

This module implements a User Equipment (UE) for a 5G LTE network.

Source:
ue: NRUe {
    @display("p=51,259");
}

Usage diagram

The following diagram shows usage relationships between types. Unresolved types are missing from the diagram.

Parameters

Name Type Default value Description
playgroundSizeX double

x size of the area the nodes are in (in meters)

playgroundSizeY double

y size of the area the nodes are in (in meters)

playgroundSizeZ double

z size of the area the nodes are in (in meters)

Properties

Name Value Description
isNetwork
display bgb=805,500

Unassigned submodule parameters

Name Type Default value Description
routingRecorder.enabled bool true
configurator.minLinkWeight double 1E-3
configurator.configureIsolatedNetworksSeparatly bool false
configurator.config xml xml("")

XML configuration parameters for IP address assignment and adding manual routes

configurator.assignAddresses bool true

assign IP addresses to all interfaces in the network

configurator.assignUniqueAddresses bool true

avoid using the same address and raise an error if not possible

configurator.assignDisjunctSubnetAddresses bool true

avoid using the same address prefix and netmask on different links when assigning IP addresses to interfaces

configurator.addStaticRoutes bool true

add static routes to the routing tables of all nodes to route to all destination interfaces (only where applicable; turn off when config file contains manual routes)

configurator.addDefaultRoutes bool true

add default routes if all routes from a source node go through the same gateway (used only if addStaticRoutes is true)

configurator.addSubnetRoutes bool true

add subnet routes instead of destination interface routes (only where applicable; used only if addStaticRoutes is true)

configurator.addDirectRoutes bool true

add direct routes (i.e. directly connected interfaces) to the routing table (used only if addStaticRoutes is true)

configurator.optimizeRoutes bool true

optimize routing tables by merging routes, the resulting routing table might route more packets than the original (used only if addStaticRoutes is true)

configurator.dumpTopology bool false

print extracted network topology to the module output

configurator.dumpLinks bool false

print recognized network links to the module output

configurator.dumpAddresses bool false

print assigned IP addresses for all interfaces to the module output

configurator.dumpRoutes bool false

print configured and optimized routing tables for all nodes to the module output

configurator.dumpConfig string ""

write configuration into the given config file that can be fed back to speed up subsequent runs (network configurations)

channelControl.coreDebug bool false

debug switch for core framework

channelControl.pMax double 20mW

maximum sending power used for this network (in mW)

channelControl.sat double -110dBm

signal attenuation threshold (in dBm)

channelControl.alpha double 2

path loss coefficient

channelControl.carrierFrequency double 2.4GHz

base carrier frequency of all the channels (in Hz)

channelControl.numChannels int 1

number of radio channels (frequencies)

binder.blerShift int 0
binder.maxDataRatePerRb double 1.16Mbps
binder.printTrafficGeneratorConfig bool false
carrierAggregation.componentCarrier.binderModule string "binder"
carrierAggregation.componentCarrier.carrierFrequency double 2GHz

Carrier Frequency (GHz) -->

carrierAggregation.componentCarrier.numBands int 6

number of bands for this channel

carrierAggregation.componentCarrier.numerologyIndex int 0

numerology index

carrierAggregation.componentCarrier.useTdd bool false
carrierAggregation.componentCarrier.tddNumSymbolsDl int 7
carrierAggregation.componentCarrier.tddNumSymbolsUl int 7
upf.status.initialStatus string "UP"

TODO @signal, @statistic

upf.pcapRecorder.verbose bool true

whether to log packets on the module output

upf.pcapRecorder.pcapFile string ""

the PCAP file to be written

upf.pcapRecorder.fileFormat string "pcapng"
upf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

upf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

upf.pcapRecorder.moduleNamePatterns string "wlan[*] eth[*] ppp[*]"

space-separated list of sibling module names to listen on

upf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

upf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

upf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

upf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

upf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

upf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

upf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
upf.interfaceTable.displayAddresses bool false

whether to display IP addresses on links

upf.cb.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

upf.cb.forwardServiceRegistration bool true
upf.cb.forwardProtocolRegistration bool true
upf.bl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

upf.bl.forwardServiceRegistration bool true
upf.bl.forwardProtocolRegistration bool true
upf.li.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

upf.li.forwardServiceRegistration bool true
upf.li.forwardProtocolRegistration bool true
upf.eth.bitrate double
upf.nl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

upf.nl.forwardServiceRegistration bool true
upf.nl.forwardProtocolRegistration bool true
upf.pppIf.pcapRecorder.verbose bool true

whether to log packets on the module output

upf.pppIf.pcapRecorder.pcapFile string ""

the PCAP file to be written

upf.pppIf.pcapRecorder.fileFormat string "pcapng"
upf.pppIf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

upf.pppIf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

upf.pppIf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

upf.pppIf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

upf.pppIf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

upf.pppIf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

upf.pppIf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

upf.pppIf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

upf.pppIf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
upf.pppIf.ppp.interfaceTableModule string

The path to the InterfaceTable module

upf.pppIf.ppp.displayStringTextFormat string "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d"
upf.pppIf.ppp.sendRawBytes bool false

when true packets are serialized into a sequence of bytes before sending out

upf.pppIf.ppp.mtu int 4470B
upf.pppIf.ppp.stopOperationExtraTime double -1s

extra time after lifecycle stop operation finished

upf.pppIf.ppp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

upf.udp.interfaceTableModule string

The path to the InterfaceTable module

upf.udp.icmpModule string "^.ipv4.icmp"
upf.udp.icmpv6Module string "^.ipv6.icmpv6"
upf.udp.crcMode string "declared"
upf.udp.defaultMulticastLoop bool true
upf.trafficFlowFilter.binderModule string "binder"
upf.trafficFlowFilter.fastForwarding bool true
upf.gtp_user.binderModule string "binder"
upf.gtp_user.interfaceTableModule string

path to the InterfaceTable module

upf.gtp_user.ipOutInterface string ""

optional: manual specification of outgoing interface for received IP

upf.gtp_user.localPort int 31
upf.gtp_user.tunnelPeerPort int 31
upf.tn.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

upf.tn.forwardServiceRegistration bool true
upf.tn.forwardProtocolRegistration bool true
upf.at.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

upf.at.forwardServiceRegistration bool true
upf.at.forwardProtocolRegistration bool true
iUpf.status.initialStatus string "UP"

TODO @signal, @statistic

iUpf.pcapRecorder.verbose bool true

whether to log packets on the module output

iUpf.pcapRecorder.pcapFile string ""

the PCAP file to be written

iUpf.pcapRecorder.fileFormat string "pcapng"
iUpf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

iUpf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

iUpf.pcapRecorder.moduleNamePatterns string "wlan[*] eth[*] ppp[*]"

space-separated list of sibling module names to listen on

iUpf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

iUpf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

iUpf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

iUpf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

iUpf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

iUpf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

iUpf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
iUpf.interfaceTable.displayAddresses bool false

whether to display IP addresses on links

iUpf.cb.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

iUpf.cb.forwardServiceRegistration bool true
iUpf.cb.forwardProtocolRegistration bool true
iUpf.bl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

iUpf.bl.forwardServiceRegistration bool true
iUpf.bl.forwardProtocolRegistration bool true
iUpf.li.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

iUpf.li.forwardServiceRegistration bool true
iUpf.li.forwardProtocolRegistration bool true
iUpf.eth.bitrate double
iUpf.nl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

iUpf.nl.forwardServiceRegistration bool true
iUpf.nl.forwardProtocolRegistration bool true
iUpf.pppIf.pcapRecorder.verbose bool true

whether to log packets on the module output

iUpf.pppIf.pcapRecorder.pcapFile string ""

the PCAP file to be written

iUpf.pppIf.pcapRecorder.fileFormat string "pcapng"
iUpf.pppIf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

iUpf.pppIf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

iUpf.pppIf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

iUpf.pppIf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

iUpf.pppIf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

iUpf.pppIf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

iUpf.pppIf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

iUpf.pppIf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

iUpf.pppIf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
iUpf.pppIf.ppp.interfaceTableModule string

The path to the InterfaceTable module

iUpf.pppIf.ppp.displayStringTextFormat string "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d"
iUpf.pppIf.ppp.sendRawBytes bool false

when true packets are serialized into a sequence of bytes before sending out

iUpf.pppIf.ppp.mtu int 4470B
iUpf.pppIf.ppp.stopOperationExtraTime double -1s

extra time after lifecycle stop operation finished

iUpf.pppIf.ppp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

iUpf.udp.interfaceTableModule string

The path to the InterfaceTable module

iUpf.udp.icmpModule string "^.ipv4.icmp"
iUpf.udp.icmpv6Module string "^.ipv6.icmpv6"
iUpf.udp.crcMode string "declared"
iUpf.udp.defaultMulticastLoop bool true
iUpf.trafficFlowFilter.binderModule string "binder"
iUpf.trafficFlowFilter.fastForwarding bool true
iUpf.gtp_user.binderModule string "binder"
iUpf.gtp_user.interfaceTableModule string

path to the InterfaceTable module

iUpf.gtp_user.ipOutInterface string ""

optional: manual specification of outgoing interface for received IP

iUpf.gtp_user.localPort int 31
iUpf.gtp_user.tunnelPeerPort int 31
iUpf.tn.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

iUpf.tn.forwardServiceRegistration bool true
iUpf.tn.forwardProtocolRegistration bool true
iUpf.at.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

iUpf.at.forwardServiceRegistration bool true
iUpf.at.forwardProtocolRegistration bool true
gNodeB1.interfaceTable.displayAddresses bool false

whether to display IP addresses on links

gNodeB1.mobility.subjectModule string "^"

module path which determines the subject module, the motion of which this mobility model describes, the default value is the parent module

gNodeB1.mobility.coordinateSystemModule string ""

module path of the geographic coordinate system module

gNodeB1.mobility.displayStringTextFormat string "p: %p\nv: %v"

format string for the mobility module's display string text

gNodeB1.mobility.updateDisplayString bool true

enables continuous update of the subject module's position via modifying its display string

gNodeB1.mobility.constraintAreaMinX double -inf m

min x position of the constraint area, unconstrained by default (negative infinity)

gNodeB1.mobility.constraintAreaMinY double -inf m

min y position of the constraint area, unconstrained by default (negative infinity)

gNodeB1.mobility.constraintAreaMinZ double -inf m

min z position of the constraint area, unconstrained by default (negative infinity)

gNodeB1.mobility.constraintAreaMaxX double inf m

max x position of the constraint area, unconstrained by default (positive infinity)

gNodeB1.mobility.constraintAreaMaxY double inf m

max y position of the constraint area, unconstrained by default (positive infinity)

gNodeB1.mobility.constraintAreaMaxZ double inf m

max z position of the constraint area, unconstrained by default (positive infinity)

gNodeB1.mobility.initialX double uniform(this.constraintAreaMinX, this.constraintAreaMaxX)
gNodeB1.mobility.initialY double uniform(this.constraintAreaMinY, this.constraintAreaMaxY)
gNodeB1.mobility.initialZ double nanToZero(uniform(this.constraintAreaMinZ, this.constraintAreaMaxZ))
gNodeB1.mobility.initialLatitude double nan deg
gNodeB1.mobility.initialLongitude double nan deg
gNodeB1.mobility.initialAltitude double 0m
gNodeB1.mobility.initialHeading double 0deg
gNodeB1.mobility.initialElevation double 0deg
gNodeB1.mobility.initialBank double 0deg
gNodeB1.mobility.initFromDisplayString bool true

enables one time initialization from the subject module's display string

gNodeB1.mobility.updateFromDisplayString bool true

enables continuous update from the subject module's display string for dragging and rotating it

gNodeB1.cellInfo.constraintAreaMinX double -1m/0

The minimum X-coordinate of the area constraint, unconstrained by default

gNodeB1.cellInfo.constraintAreaMinY double -1m/0

The minimum Y-coordinate of the area constraint, unconstrained by default

gNodeB1.cellInfo.constraintAreaMaxX double 1m/0

The maximum X-coordinate of the area constraint, unconstrained by default

gNodeB1.cellInfo.constraintAreaMaxY double 1m/0

The maximum Y-coordinate of the area constraint, unconstrained by default

gNodeB1.cellInfo.broadcastMessageInterval double 1s

Interval for sending broadcast messages (used for handover or DAS)

gNodeB1.cellInfo.microCell bool false

Type of eNodeB (MICRO / MACRO) - valid only for eNodeBs

gNodeB1.cellInfo.numRus int 0

Number of Remote Units

gNodeB1.cellInfo.ruRange int 0

Range of Remote Units

gNodeB1.cellInfo.ruStartingAngle double 0deg

Initial angle for remote units (used for graphical representation)

gNodeB1.cellInfo.ruTxPower string "0;"

CSV string specifying the TX power for each remote unit (integer values)

gNodeB1.cellInfo.antennaCws string "1;"

Codewords for each antenna, first position refers to the MACRO

gNodeB1.cellInfo.rbyDl int 12

Number of sub-carriers per RB in DL

gNodeB1.cellInfo.rbyUl int 12

Number of sub-carriers per RB in UL

gNodeB1.cellInfo.rbxDl int 7

Number of OFDM symbols per slot in DL

gNodeB1.cellInfo.rbxUl int 7

Number of OFDM symbols per slot in UL

gNodeB1.cellInfo.rbPilotDl int 3

Number of pilot Resource Elements per RB in DL

gNodeB1.cellInfo.rbPilotUl int 0

Number of pilot Resource Elements per RB in UL

gNodeB1.cellInfo.signalDl int 1

Number of signaling symbols for each Resource Block in DL

gNodeB1.cellInfo.signalUl int 1

Number of signaling symbols for each Resource Block in UL

gNodeB1.cellInfo.numPreferredBands int 1

Number of preferred bands to use (relevant only in PREFERRED mode)

gNodeB1.cellInfo.binderModule string "binder"
gNodeB1.collector.collectorType string

it can be: "eNBStatsCollector, gNBStatsCollector, ueStatsCollector, NRueStatsCollector

gNodeB1.pppIf.pcapRecorder.verbose bool true

whether to log packets on the module output

gNodeB1.pppIf.pcapRecorder.pcapFile string ""

the PCAP file to be written

gNodeB1.pppIf.pcapRecorder.fileFormat string "pcapng"
gNodeB1.pppIf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

gNodeB1.pppIf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

gNodeB1.pppIf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

gNodeB1.pppIf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

gNodeB1.pppIf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

gNodeB1.pppIf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

gNodeB1.pppIf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

gNodeB1.pppIf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

gNodeB1.pppIf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
gNodeB1.pppIf.ppp.interfaceTableModule string

The path to the InterfaceTable module

gNodeB1.pppIf.ppp.displayStringTextFormat string "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d"
gNodeB1.pppIf.ppp.sendRawBytes bool false

when true packets are serialized into a sequence of bytes before sending out

gNodeB1.pppIf.ppp.mtu int 4470B
gNodeB1.pppIf.ppp.stopOperationExtraTime double -1s

extra time after lifecycle stop operation finished

gNodeB1.pppIf.ppp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

gNodeB1.x2ppp.pcapRecorder.verbose bool true

whether to log packets on the module output

gNodeB1.x2ppp.pcapRecorder.pcapFile string ""

the PCAP file to be written

gNodeB1.x2ppp.pcapRecorder.fileFormat string "pcapng"
gNodeB1.x2ppp.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

gNodeB1.x2ppp.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

gNodeB1.x2ppp.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

gNodeB1.x2ppp.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

gNodeB1.x2ppp.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

gNodeB1.x2ppp.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

gNodeB1.x2ppp.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

gNodeB1.x2ppp.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

gNodeB1.x2ppp.pcapRecorder.displayStringTextFormat string "rec: %n pks"
gNodeB1.x2ppp.ppp.interfaceTableModule string

The path to the InterfaceTable module

gNodeB1.x2ppp.ppp.displayStringTextFormat string "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d"
gNodeB1.x2ppp.ppp.sendRawBytes bool false

when true packets are serialized into a sequence of bytes before sending out

gNodeB1.x2ppp.ppp.mtu int 4470B
gNodeB1.x2ppp.ppp.stopOperationExtraTime double -1s

extra time after lifecycle stop operation finished

gNodeB1.x2ppp.ppp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

gNodeB1.pppMEHostIf.pcapRecorder.verbose bool true

whether to log packets on the module output

gNodeB1.pppMEHostIf.pcapRecorder.pcapFile string ""

the PCAP file to be written

gNodeB1.pppMEHostIf.pcapRecorder.fileFormat string "pcapng"
gNodeB1.pppMEHostIf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

gNodeB1.pppMEHostIf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

gNodeB1.pppMEHostIf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

gNodeB1.pppMEHostIf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

gNodeB1.pppMEHostIf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

gNodeB1.pppMEHostIf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

gNodeB1.pppMEHostIf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

gNodeB1.pppMEHostIf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

gNodeB1.pppMEHostIf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
gNodeB1.pppMEHostIf.ppp.interfaceTableModule string

The path to the InterfaceTable module

gNodeB1.pppMEHostIf.ppp.displayStringTextFormat string "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d"
gNodeB1.pppMEHostIf.ppp.sendRawBytes bool false

when true packets are serialized into a sequence of bytes before sending out

gNodeB1.pppMEHostIf.ppp.mtu int 4470B
gNodeB1.pppMEHostIf.ppp.stopOperationExtraTime double -1s

extra time after lifecycle stop operation finished

gNodeB1.pppMEHostIf.ppp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

gNodeB1.udp.interfaceTableModule string

The path to the InterfaceTable module

gNodeB1.udp.icmpModule string "^.ipv4.icmp"
gNodeB1.udp.icmpv6Module string "^.ipv6.icmpv6"
gNodeB1.udp.crcMode string "declared"
gNodeB1.udp.defaultMulticastLoop bool true
gNodeB1.tcp.crcMode string "declared"
gNodeB1.tcp.advertisedWindow int 14*this.mss

in bytes, corresponds with the maximal receiver buffer capacity (Note: normally, NIC queues should be at least this size)

gNodeB1.tcp.delayedAcksEnabled bool false

delayed ACK algorithm (RFC 1122) enabled/disabled

gNodeB1.tcp.nagleEnabled bool true

Nagle's algorithm (RFC 896) enabled/disabled

gNodeB1.tcp.limitedTransmitEnabled bool false

Limited Transmit algorithm (RFC 3042) enabled/disabled (can be used for TcpReno/TcpTahoe/TcpNewReno/TcpNoCongestionControl)

gNodeB1.tcp.increasedIWEnabled bool false

Increased Initial Window (RFC 3390) enabled/disabled

gNodeB1.tcp.sackSupport bool false

Selective Acknowledgment (RFC 2018, 2883, 3517) support (header option) (SACK will be enabled for a connection if both endpoints support it)

gNodeB1.tcp.windowScalingSupport bool false

Window Scale (RFC 1323) support (header option) (WS will be enabled for a connection if both endpoints support it)

gNodeB1.tcp.windowScalingFactor int -1

Window Scaling Factor to the power of 2. -1 indicates that manual window scaling is turned off.

gNodeB1.tcp.timestampSupport bool false

Timestamps (RFC 1323) support (header option) (TS will be enabled for a connection if both endpoints support it)

gNodeB1.tcp.mss int 536

Maximum Segment Size (RFC 793) (header option)

gNodeB1.tcp.msl int 120s

Maximum Segment Lifetime

gNodeB1.tcp.tcpAlgorithmClass string "TcpReno"

TODO: use the following @enum or similar, but it must allow new values for user defined algorithms (omnetpp-6.1 checks @enum strictly): @enum("TcpVegas", "TcpWestwood", "TcpNewReno", "TcpReno", "TcpTahoe", "TcpNoCongestionControl")

gNodeB1.tcp.useDataNotification bool false

turn the notifications for arrived data on or off

gNodeB1.tcp.dupthresh int 3

used for TcpTahoe, TcpReno and SACK (RFC 3517) DO NOT change unless you really know what you are doing

gNodeB1.tcp.initialSsthresh int 0xFFFFFFFF

initial value for Slow Start threshold used in TahoeRenoFamily. The initial value of ssthresh SHOULD be set arbitrarily high (e.g.,to the size of the largest possible advertised window) Without user interaction there is no limit...

gNodeB1.tcp.stopOperationExtraTime double 0s

extra time after lifecycle stop operation finished

gNodeB1.tcp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

gNodeB1.tcp.ecnWillingness bool false

true if willing to use ECN

gNodeB1.tcp.dctcpGamma double 0.0625

A fixed estimation gain for calculating dctcp_alpha (RFC 8257 4.2)

gNodeB1.x2App.client.localAddress string ""

comma separated list of addresses

gNodeB1.x2App.client.localPort int 0

port number to listen on

gNodeB1.x2App.client.connectAddress string

server address (may be symbolic)

gNodeB1.x2App.client.connectPort int 5000

port number to connect to

gNodeB1.x2App.client.startTime double 0s

time first session begins

gNodeB1.x2App.client.numRequestsPerSession int 1

number of requests sent per session

gNodeB1.x2App.client.numPacketsToReceive int 0
gNodeB1.x2App.client.requestLength int 1452

length of a request (bytes)

gNodeB1.x2App.client.thinkTime double 0s

time gap between requests

gNodeB1.x2App.client.waitToClose double 0s

time to wait between last message sent and abort

gNodeB1.x2App.client.reconnectInterval double 0s

if connection breaks, waits this much before trying to reconnect

gNodeB1.x2App.client.inboundStreams int 17
gNodeB1.x2App.client.outboundStreams int 1
gNodeB1.x2App.client.echo bool false

echoes received packages when true

gNodeB1.x2App.client.ordered bool true
gNodeB1.x2App.client.queueSize int 0
gNodeB1.x2App.client.prMethod int 0

0=NONE, 1=PR_TTL, 2=PR_RTX, 3=PR_PRIO, 4=PR_STRRST

gNodeB1.x2App.client.prValue double 0

for PR-SCTP

gNodeB1.x2App.client.streamReset bool false
gNodeB1.x2App.client.streamRequestTime double 0s
gNodeB1.x2App.client.streamResetType int 5

NO_RESET=5, RESET_OUTGOING=6, RESET_INCOMING=7, RESET_BOTH=8, SSN_TSN=9

gNodeB1.x2App.client.streamToReset int 0
gNodeB1.x2App.client.stopTime double -1s

time of finishing sending, negative values mean forever

gNodeB1.x2App.client.primaryTime double 0s
gNodeB1.x2App.client.newPrimary string ""
gNodeB1.x2App.client.streamRequestLengths string ""
gNodeB1.x2App.client.streamRequestRatio string ""
gNodeB1.x2App.client.streamPriorities string ""
gNodeB1.x2App.client.finishEndsSimulation bool false
gNodeB1.x2App.client.binderModule string "binder"
gNodeB1.x2App.server.localAddress string ""

comma separated list of addresses

gNodeB1.x2App.server.localPort int 0

port number to listen on

gNodeB1.x2App.server.echo bool false

echoes received packages when true

gNodeB1.x2App.server.echoDelay double 0s
gNodeB1.x2App.server.delayFirstRead double 0s
gNodeB1.x2App.server.readingInterval double 0s
gNodeB1.x2App.server.messagesToPush int 0
gNodeB1.x2App.server.numPacketsToSendPerClient int 0

number of requests sent per session

gNodeB1.x2App.server.numPacketsToReceivePerClient int 1
gNodeB1.x2App.server.requestLength int 1452

length of a request (bytes)

gNodeB1.x2App.server.thinkTime double 0s

time gap between requests

gNodeB1.x2App.server.waitToClose double 0s

time to wait between last message sent and abort

gNodeB1.x2App.server.finishEndsSimulation bool false
gNodeB1.x2App.server.ordered bool true
gNodeB1.x2App.server.inboundStreams int 17
gNodeB1.x2App.server.outboundStreams int 1
gNodeB1.x2App.server.queueSize int 0
gNodeB1.x2App.server.prMethod int 0

0=NONE, 1=PR_TTL, 2=PR_RTX, 3=PR_PRIO, 4=PR_STRRST

gNodeB1.x2App.server.prValue double 0

for PR-SCTP

gNodeB1.x2App.server.streamReset bool false
gNodeB1.x2App.server.streamRequestTime double 0s
gNodeB1.x2App.server.streamToReset int 0
gNodeB1.x2App.server.streamPriorities string ""
gNodeB1.x2App.server.binderModule string "binder"
gNodeB1.sctp.interfaceTableModule string
gNodeB1.sctp.routingTableModule string
gNodeB1.sctp.crcMode string "declared"
gNodeB1.sctp.numGapReports int 3
gNodeB1.sctp.rtoInitial double 3s
gNodeB1.sctp.rtoMin double 1s
gNodeB1.sctp.rtoMax double 60s
gNodeB1.sctp.rtoAlpha double 0.125
gNodeB1.sctp.rtoBeta double 0.250
gNodeB1.sctp.maxBurst int 4
gNodeB1.sctp.maxBurstVariant string "maxBurst"
gNodeB1.sctp.initialWindow int 0
gNodeB1.sctp.assocMaxRetrans int 10
gNodeB1.sctp.pathMaxRetrans int 5
gNodeB1.sctp.maxInitRetrans int 8
gNodeB1.sctp.sackPeriod double 200ms
gNodeB1.sctp.sackFrequency int 2
gNodeB1.sctp.reactivatePrimaryPath bool false
gNodeB1.sctp.sendQueueLimit int 0
gNodeB1.sctp.validCookieLifetime double 10s
gNodeB1.sctp.enableHeartbeats bool true
gNodeB1.sctp.hbInterval double 30s
gNodeB1.sctp.sendHeartbeatsOnActivePaths bool false
gNodeB1.sctp.nagleEnabled bool true
gNodeB1.sctp.naglePoint int 1468
gNodeB1.sctp.fragPoint int 1452
gNodeB1.sctp.fastRecoverySupported bool true
gNodeB1.sctp.sctpAlgorithmClass string "SctpAlg"
gNodeB1.sctp.ccModule int 0

RFC4960=0

gNodeB1.sctp.osbWithHeader bool false
gNodeB1.sctp.RTXMethod int 0

0=Once after 3 Sacks; 1=once per RTT; 2=Switch off Fast Retransmit; 3=Always after 3 Sacks

gNodeB1.sctp.ssModule int 0
gNodeB1.sctp.arwnd int 65535
gNodeB1.sctp.swsLimit int 3000

Limit for SWS

gNodeB1.sctp.udpEncapsEnabled bool false
gNodeB1.sctp.natFriendly bool false
gNodeB1.sctp.bytesToAddPerRcvdChunk int 0

for flowcontrol

gNodeB1.sctp.bytesToAddPerPeerChunk int 0

for flowcontrol

gNodeB1.sctp.tellArwnd bool false

for flowcontrol

gNodeB1.sctp.messageAcceptLimit int 0

for flowcontrol

gNodeB1.sctp.fairStart double 0s
gNodeB1.sctp.fairStop double 0s
gNodeB1.sctp.streamsToPaths string ""
gNodeB1.sctp.startEndToEndDelay int 0
gNodeB1.sctp.stopEndToEndDelay int 10
gNodeB1.sctp.throughputInterval double 1
gNodeB1.sctp.auth bool false
gNodeB1.sctp.chunks string ""
gNodeB1.sctp.padding bool false
gNodeB1.sctp.addIP bool false
gNodeB1.sctp.addTime double 0s
gNodeB1.sctp.addAddress string ""
gNodeB1.sctp.addIpType string "0"

SET_PRIMARY_ADDRESS=49156,ADD_IP_ADDRESS=49153,DELETE_IP_ADDRESS=49154

gNodeB1.sctp.packetDrop bool false
gNodeB1.sctp.sackNow bool false
gNodeB1.sctp.highSpeedCC bool false
gNodeB1.sctp.checkSackSeqNumber bool false
gNodeB1.sctp.nrSack bool false
gNodeB1.sctp.disableReneging bool false
gNodeB1.sctp.gapReportLimit int 100000000
gNodeB1.sctp.gapListOptimizationVariant string "none"
gNodeB1.sctp.smartOverfullSACKHandling bool false
gNodeB1.sctp.allowQoSTracking bool false
gNodeB1.sctp.qosTrackingInterval double 1.0s
gNodeB1.sctp.cmtSendAllVariant string "normal"
gNodeB1.sctp.cmtRetransmissionVariant string "normal"
gNodeB1.sctp.cmtCUCVariant string "normal"
gNodeB1.sctp.cmtBufferSplitVariant string "none"
gNodeB1.sctp.cmtBufferSplittingUsesOSB bool false
gNodeB1.sctp.cmtUseSFR bool true
gNodeB1.sctp.cmtUseDAC bool true
gNodeB1.sctp.cmtUseFRC bool true
gNodeB1.sctp.cmtSmartT3Reset bool true
gNodeB1.sctp.cmtSmartFastRTX bool true
gNodeB1.sctp.cmtSmartReneging bool false
gNodeB1.sctp.cmtSlowPathRTTUpdate bool false
gNodeB1.sctp.cmtChunkReschedulingVariant string "none"
gNodeB1.sctp.cmtChunkReschedulingThreshold double 0.5
gNodeB1.sctp.cmtMovedChunksReduceCwnd bool true
gNodeB1.sctp.movedChunkFastRTXFactor double 2.0
gNodeB1.sctp.cmtSackPath string "standard"
gNodeB1.sctp.strictCwndBooking bool false
gNodeB1.sctp.cmtCCVariant string "off"

CMT Congestion Control Variant off = use over every path the default RFC4960 CC (New Reno) lia = First resource pooling congestion control RFC6356 adapted for SCTP - https://datatracker.ietf.org/doc/rfc6356/ olia = alternative MPTCP CC, adapted for SCTP- https://tools.ietf.org/html/draft-khalili-mptcp-congestion-control-05 cmtrpv1 = First resource pooling based CC for SCTP - https://www.tdr.wiwi.uni-due.de/fileadmin/fileupload/I-TDR/SCTP/Paper/AINA2010.pdf cmtrpv2 = Updated version of cmtrpv1 - https://www.tdr.wiwi.uni-due.de/fileadmin/fileupload/I-TDR/SCTP/Paper/ConTEL2011.pdf

gNodeB1.sctp.cmtCCPathGroups string ""
gNodeB1.sctp.rpPathBlocking bool false
gNodeB1.sctp.rpScaleBlockingTimeout bool false
gNodeB1.sctp.rpMinCwnd int 1
gNodeB1.at.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

gNodeB1.at.forwardServiceRegistration bool true
gNodeB1.at.forwardProtocolRegistration bool true
gNodeB1.tn.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

gNodeB1.tn.forwardServiceRegistration bool true
gNodeB1.tn.forwardProtocolRegistration bool true
gNodeB1.nl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

gNodeB1.nl.forwardServiceRegistration bool true
gNodeB1.nl.forwardProtocolRegistration bool true
gNodeB1.trafficFlowFilter.binderModule string "binder"
gNodeB1.trafficFlowFilter.fastForwarding bool true
gNodeB1.gtpUser.binderModule string "binder"
gNodeB1.gtpUser.interfaceTableModule string

path to the InterfaceTable module

gNodeB1.gtpUser.localPort int 31
gNodeB1.gtpUser.tunnelPeerPort int 31
gNodeB1.gtpUserX2.binderModule string "binder"
gNodeB1.gtpUserX2.localPort int 32
gNodeB1.gtpUserX2.tunnelPeerPort int 32
mecHost1.virtualisationInfrastructure.interfaceTable.displayAddresses bool false

whether to display IP addresses on links

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.verbose bool true

whether to log packets on the module output

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.pcapFile string ""

the PCAP file to be written

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.fileFormat string "pcapng"
mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

mecHost1.virtualisationInfrastructure.pppIf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
mecHost1.virtualisationInfrastructure.pppIf.ppp.interfaceTableModule string

The path to the InterfaceTable module

mecHost1.virtualisationInfrastructure.pppIf.ppp.displayStringTextFormat string "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d"
mecHost1.virtualisationInfrastructure.pppIf.ppp.sendRawBytes bool false

when true packets are serialized into a sequence of bytes before sending out

mecHost1.virtualisationInfrastructure.pppIf.ppp.mtu int 4470B
mecHost1.virtualisationInfrastructure.pppIf.ppp.stopOperationExtraTime double -1s

extra time after lifecycle stop operation finished

mecHost1.virtualisationInfrastructure.pppIf.ppp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

mecHost1.virtualisationInfrastructure.extEth.bitrate double
mecHost1.virtualisationInfrastructure.udp.interfaceTableModule string

The path to the InterfaceTable module

mecHost1.virtualisationInfrastructure.udp.icmpModule string "^.ipv4.icmp"
mecHost1.virtualisationInfrastructure.udp.icmpv6Module string "^.ipv6.icmpv6"
mecHost1.virtualisationInfrastructure.udp.crcMode string "declared"
mecHost1.virtualisationInfrastructure.udp.defaultMulticastLoop bool true
mecHost1.virtualisationInfrastructure.tcp.crcMode string "declared"
mecHost1.virtualisationInfrastructure.tcp.advertisedWindow int 14*this.mss

in bytes, corresponds with the maximal receiver buffer capacity (Note: normally, NIC queues should be at least this size)

mecHost1.virtualisationInfrastructure.tcp.delayedAcksEnabled bool false

delayed ACK algorithm (RFC 1122) enabled/disabled

mecHost1.virtualisationInfrastructure.tcp.nagleEnabled bool true

Nagle's algorithm (RFC 896) enabled/disabled

mecHost1.virtualisationInfrastructure.tcp.limitedTransmitEnabled bool false

Limited Transmit algorithm (RFC 3042) enabled/disabled (can be used for TcpReno/TcpTahoe/TcpNewReno/TcpNoCongestionControl)

mecHost1.virtualisationInfrastructure.tcp.increasedIWEnabled bool false

Increased Initial Window (RFC 3390) enabled/disabled

mecHost1.virtualisationInfrastructure.tcp.sackSupport bool false

Selective Acknowledgment (RFC 2018, 2883, 3517) support (header option) (SACK will be enabled for a connection if both endpoints support it)

mecHost1.virtualisationInfrastructure.tcp.windowScalingSupport bool false

Window Scale (RFC 1323) support (header option) (WS will be enabled for a connection if both endpoints support it)

mecHost1.virtualisationInfrastructure.tcp.windowScalingFactor int -1

Window Scaling Factor to the power of 2. -1 indicates that manual window scaling is turned off.

mecHost1.virtualisationInfrastructure.tcp.timestampSupport bool false

Timestamps (RFC 1323) support (header option) (TS will be enabled for a connection if both endpoints support it)

mecHost1.virtualisationInfrastructure.tcp.mss int 536

Maximum Segment Size (RFC 793) (header option)

mecHost1.virtualisationInfrastructure.tcp.msl int 120s

Maximum Segment Lifetime

mecHost1.virtualisationInfrastructure.tcp.tcpAlgorithmClass string "TcpReno"

TODO: use the following @enum or similar, but it must allow new values for user defined algorithms (omnetpp-6.1 checks @enum strictly): @enum("TcpVegas", "TcpWestwood", "TcpNewReno", "TcpReno", "TcpTahoe", "TcpNoCongestionControl")

mecHost1.virtualisationInfrastructure.tcp.useDataNotification bool false

turn the notifications for arrived data on or off

mecHost1.virtualisationInfrastructure.tcp.dupthresh int 3

used for TcpTahoe, TcpReno and SACK (RFC 3517) DO NOT change unless you really know what you are doing

mecHost1.virtualisationInfrastructure.tcp.initialSsthresh int 0xFFFFFFFF

initial value for Slow Start threshold used in TahoeRenoFamily. The initial value of ssthresh SHOULD be set arbitrarily high (e.g.,to the size of the largest possible advertised window) Without user interaction there is no limit...

mecHost1.virtualisationInfrastructure.tcp.stopOperationExtraTime double 0s

extra time after lifecycle stop operation finished

mecHost1.virtualisationInfrastructure.tcp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

mecHost1.virtualisationInfrastructure.tcp.ecnWillingness bool false

true if willing to use ECN

mecHost1.virtualisationInfrastructure.tcp.dctcpGamma double 0.0625

A fixed estimation gain for calculating dctcp_alpha (RFC 8257 4.2)

mecHost1.virtualisationInfrastructure.at.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.virtualisationInfrastructure.at.forwardServiceRegistration bool true
mecHost1.virtualisationInfrastructure.at.forwardProtocolRegistration bool true
mecHost1.virtualisationInfrastructure.tn.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.virtualisationInfrastructure.tn.forwardServiceRegistration bool true
mecHost1.virtualisationInfrastructure.tn.forwardProtocolRegistration bool true
mecHost1.virtualisationInfrastructure.nl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.virtualisationInfrastructure.nl.forwardServiceRegistration bool true
mecHost1.virtualisationInfrastructure.nl.forwardProtocolRegistration bool true
mecHost1.mecPlatform.serviceRegistry.serviceName string "ServiceRegistry"
mecHost1.mecPlatform.serviceRegistry.requestQueueSize int 0
mecHost1.mecPlatform.serviceRegistry.subscriptionQueueSize int 0
mecHost1.mecPlatform.serviceRegistry.localAddress string ""

local address; may be left empty ("")

mecHost1.mecPlatform.serviceRegistry.localPort int 1000

localPort number to listen on

mecHost1.mecPlatform.serviceRegistry.requestServiceTime double 15us
mecHost1.mecPlatform.serviceRegistry.subscriptionServiceTime double 20us
mecHost1.mecPlatform.serviceRegistry.serverThreadClass string "simu5g.nodes.mec.MECPlatform.MECServices.MECServiceBase.SocketManager"
mecHost1.mecPlatform.serviceRegistry.tos int -1

if not -1, set the Type Of Service (IPv4) / Traffic Class (IPv6) field of sent packets to this value

mecHost1.mecPlatform.serviceRegistry.binderModule string "binder"
mecHost1.mecPlatformManager.mecOrchestrator string
mecHost1.mecPlatformManager.serviceRegistryModule string "^.mecPlatform.serviceRegistry"
mecHost1.mecPlatformManager.vimModule string "^.vim"
mecHost1.vim.binderModule string "binder"
mecHost1.vim.mp1Port int 10021
mecHost1.vim.scheduling string "segregation"
mecHost1.upf_mec.status.initialStatus string "UP"

TODO @signal, @statistic

mecHost1.upf_mec.pcapRecorder.verbose bool true

whether to log packets on the module output

mecHost1.upf_mec.pcapRecorder.pcapFile string ""

the PCAP file to be written

mecHost1.upf_mec.pcapRecorder.fileFormat string "pcapng"
mecHost1.upf_mec.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

mecHost1.upf_mec.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

mecHost1.upf_mec.pcapRecorder.moduleNamePatterns string "wlan[*] eth[*] ppp[*]"

space-separated list of sibling module names to listen on

mecHost1.upf_mec.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

mecHost1.upf_mec.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

mecHost1.upf_mec.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

mecHost1.upf_mec.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

mecHost1.upf_mec.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

mecHost1.upf_mec.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

mecHost1.upf_mec.pcapRecorder.displayStringTextFormat string "rec: %n pks"
mecHost1.upf_mec.interfaceTable.displayAddresses bool false

whether to display IP addresses on links

mecHost1.upf_mec.cb.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.upf_mec.cb.forwardServiceRegistration bool true
mecHost1.upf_mec.cb.forwardProtocolRegistration bool true
mecHost1.upf_mec.bl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.upf_mec.bl.forwardServiceRegistration bool true
mecHost1.upf_mec.bl.forwardProtocolRegistration bool true
mecHost1.upf_mec.li.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.upf_mec.li.forwardServiceRegistration bool true
mecHost1.upf_mec.li.forwardProtocolRegistration bool true
mecHost1.upf_mec.eth.bitrate double
mecHost1.upf_mec.nl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.upf_mec.nl.forwardServiceRegistration bool true
mecHost1.upf_mec.nl.forwardProtocolRegistration bool true
mecHost1.upf_mec.pppIf.pcapRecorder.verbose bool true

whether to log packets on the module output

mecHost1.upf_mec.pppIf.pcapRecorder.pcapFile string ""

the PCAP file to be written

mecHost1.upf_mec.pppIf.pcapRecorder.fileFormat string "pcapng"
mecHost1.upf_mec.pppIf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

mecHost1.upf_mec.pppIf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

mecHost1.upf_mec.pppIf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

mecHost1.upf_mec.pppIf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

mecHost1.upf_mec.pppIf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

mecHost1.upf_mec.pppIf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

mecHost1.upf_mec.pppIf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

mecHost1.upf_mec.pppIf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

mecHost1.upf_mec.pppIf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
mecHost1.upf_mec.pppIf.ppp.interfaceTableModule string

The path to the InterfaceTable module

mecHost1.upf_mec.pppIf.ppp.displayStringTextFormat string "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d"
mecHost1.upf_mec.pppIf.ppp.sendRawBytes bool false

when true packets are serialized into a sequence of bytes before sending out

mecHost1.upf_mec.pppIf.ppp.mtu int 4470B
mecHost1.upf_mec.pppIf.ppp.stopOperationExtraTime double -1s

extra time after lifecycle stop operation finished

mecHost1.upf_mec.pppIf.ppp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

mecHost1.upf_mec.udp.interfaceTableModule string

The path to the InterfaceTable module

mecHost1.upf_mec.udp.icmpModule string "^.ipv4.icmp"
mecHost1.upf_mec.udp.icmpv6Module string "^.ipv6.icmpv6"
mecHost1.upf_mec.udp.crcMode string "declared"
mecHost1.upf_mec.udp.defaultMulticastLoop bool true
mecHost1.upf_mec.trafficFlowFilter.binderModule string "binder"
mecHost1.upf_mec.trafficFlowFilter.fastForwarding bool true
mecHost1.upf_mec.gtp_user.binderModule string "binder"
mecHost1.upf_mec.gtp_user.interfaceTableModule string

path to the InterfaceTable module

mecHost1.upf_mec.gtp_user.ipOutInterface string ""

optional: manual specification of outgoing interface for received IP

mecHost1.upf_mec.gtp_user.localPort int 31
mecHost1.upf_mec.gtp_user.tunnelPeerPort int 31
mecHost1.upf_mec.tn.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.upf_mec.tn.forwardServiceRegistration bool true
mecHost1.upf_mec.tn.forwardProtocolRegistration bool true
mecHost1.upf_mec.at.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

mecHost1.upf_mec.at.forwardServiceRegistration bool true
mecHost1.upf_mec.at.forwardProtocolRegistration bool true
mecOrchestrator.binderModule string "binder"
mecOrchestrator.selectionPolicy string "MecServiceBased"

available policies: "MecHostBased", "MecServiceBased", "AvailableResourcesBased"

mecOrchestrator.mecHostIndex int 0

to be used with the MecHostBased policybased

mecOrchestrator.mecHostList object []
mecOrchestrator.mecApplicationPackageList object []
mecOrchestrator.onboardingTime double 50ms

times to simulate lifecycle operations

mecOrchestrator.instantiationTime double 50ms
mecOrchestrator.terminationTime double 50ms
ualcmp.interfaceTable.displayAddresses bool false

whether to display IP addresses on links

ualcmp.pppIf.pcapRecorder.verbose bool true

whether to log packets on the module output

ualcmp.pppIf.pcapRecorder.pcapFile string ""

the PCAP file to be written

ualcmp.pppIf.pcapRecorder.fileFormat string "pcapng"
ualcmp.pppIf.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

ualcmp.pppIf.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

ualcmp.pppIf.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

ualcmp.pppIf.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

ualcmp.pppIf.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

ualcmp.pppIf.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

ualcmp.pppIf.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

ualcmp.pppIf.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

ualcmp.pppIf.pcapRecorder.displayStringTextFormat string "rec: %n pks"
ualcmp.pppIf.ppp.interfaceTableModule string

The path to the InterfaceTable module

ualcmp.pppIf.ppp.displayStringTextFormat string "rate: %b\nsent: %s, rcvd: %r\nqueue: %q, drop: %d"
ualcmp.pppIf.ppp.sendRawBytes bool false

when true packets are serialized into a sequence of bytes before sending out

ualcmp.pppIf.ppp.mtu int 4470B
ualcmp.pppIf.ppp.stopOperationExtraTime double -1s

extra time after lifecycle stop operation finished

ualcmp.pppIf.ppp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

ualcmp.extEth.bitrate double
ualcmp.ualcmpApp.binderModule string "binder"
ualcmp.ualcmpApp.serviceName string "UALCMP"
ualcmp.ualcmpApp.requestQueueSize int 0
ualcmp.ualcmpApp.subscriptionQueueSize int 0
ualcmp.ualcmpApp.localAddress string ""

local address; may be left empty ("")

ualcmp.ualcmpApp.localPort int 1000

localPort number to listen on

ualcmp.ualcmpApp.requestServiceTime double 5us
ualcmp.ualcmpApp.subscriptionServiceTime double 10us
ualcmp.ualcmpApp.serverThreadClass string "simu5g.nodes.mec.MECPlatform.MECServices.MECServiceBase.SocketManager"
ualcmp.ualcmpApp.tos int -1

if not -1, set the Type Of Service (IPv4) / Traffic Class (IPv6) field of sent packets to this value

ualcmp.udp.interfaceTableModule string

The path to the InterfaceTable module

ualcmp.udp.icmpModule string "^.ipv4.icmp"
ualcmp.udp.icmpv6Module string "^.ipv6.icmpv6"
ualcmp.udp.crcMode string "declared"
ualcmp.udp.defaultMulticastLoop bool true
ualcmp.tcp.crcMode string "declared"
ualcmp.tcp.advertisedWindow int 14*this.mss

in bytes, corresponds with the maximal receiver buffer capacity (Note: normally, NIC queues should be at least this size)

ualcmp.tcp.delayedAcksEnabled bool false

delayed ACK algorithm (RFC 1122) enabled/disabled

ualcmp.tcp.nagleEnabled bool true

Nagle's algorithm (RFC 896) enabled/disabled

ualcmp.tcp.limitedTransmitEnabled bool false

Limited Transmit algorithm (RFC 3042) enabled/disabled (can be used for TcpReno/TcpTahoe/TcpNewReno/TcpNoCongestionControl)

ualcmp.tcp.increasedIWEnabled bool false

Increased Initial Window (RFC 3390) enabled/disabled

ualcmp.tcp.sackSupport bool false

Selective Acknowledgment (RFC 2018, 2883, 3517) support (header option) (SACK will be enabled for a connection if both endpoints support it)

ualcmp.tcp.windowScalingSupport bool false

Window Scale (RFC 1323) support (header option) (WS will be enabled for a connection if both endpoints support it)

ualcmp.tcp.windowScalingFactor int -1

Window Scaling Factor to the power of 2. -1 indicates that manual window scaling is turned off.

ualcmp.tcp.timestampSupport bool false

Timestamps (RFC 1323) support (header option) (TS will be enabled for a connection if both endpoints support it)

ualcmp.tcp.mss int 536

Maximum Segment Size (RFC 793) (header option)

ualcmp.tcp.msl int 120s

Maximum Segment Lifetime

ualcmp.tcp.tcpAlgorithmClass string "TcpReno"

TODO: use the following @enum or similar, but it must allow new values for user defined algorithms (omnetpp-6.1 checks @enum strictly): @enum("TcpVegas", "TcpWestwood", "TcpNewReno", "TcpReno", "TcpTahoe", "TcpNoCongestionControl")

ualcmp.tcp.useDataNotification bool false

turn the notifications for arrived data on or off

ualcmp.tcp.dupthresh int 3

used for TcpTahoe, TcpReno and SACK (RFC 3517) DO NOT change unless you really know what you are doing

ualcmp.tcp.initialSsthresh int 0xFFFFFFFF

initial value for Slow Start threshold used in TahoeRenoFamily. The initial value of ssthresh SHOULD be set arbitrarily high (e.g.,to the size of the largest possible advertised window) Without user interaction there is no limit...

ualcmp.tcp.stopOperationExtraTime double 0s

extra time after lifecycle stop operation finished

ualcmp.tcp.stopOperationTimeout double 2s

timeout value for lifecycle stop operation

ualcmp.tcp.ecnWillingness bool false

true if willing to use ECN

ualcmp.tcp.dctcpGamma double 0.0625

A fixed estimation gain for calculating dctcp_alpha (RFC 8257 4.2)

ualcmp.at.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

ualcmp.at.forwardServiceRegistration bool true
ualcmp.at.forwardProtocolRegistration bool true
ualcmp.tn.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

ualcmp.tn.forwardServiceRegistration bool true
ualcmp.tn.forwardProtocolRegistration bool true
ualcmp.nl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

ualcmp.nl.forwardServiceRegistration bool true
ualcmp.nl.forwardProtocolRegistration bool true
ue.interfaceTable.displayAddresses bool false

whether to display IP addresses on links

ue.eth.bitrate double
ue.at.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

ue.at.forwardServiceRegistration bool true
ue.at.forwardProtocolRegistration bool true
ue.tn.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

ue.tn.forwardServiceRegistration bool true
ue.tn.forwardProtocolRegistration bool true
ue.nl.displayStringTextFormat string "processed %p pk (%l)"

determines the text that is written on top of the submodule

ue.nl.forwardServiceRegistration bool true
ue.nl.forwardProtocolRegistration bool true
ue.pcapRecorder.verbose bool true

whether to log packets on the module output

ue.pcapRecorder.pcapFile string ""

the PCAP file to be written

ue.pcapRecorder.fileFormat string "pcapng"
ue.pcapRecorder.snaplen int 65535

maximum number of bytes to record per packet

ue.pcapRecorder.dumpBadFrames bool true

enable dump of frames with hasBitError

ue.pcapRecorder.moduleNamePatterns string "wlan[*] eth[*] ppp[*]"

space-separated list of sibling module names to listen on

ue.pcapRecorder.sendingSignalNames string "packetSentToLower"

space-separated list of outbound packet signals to subscribe to

ue.pcapRecorder.receivingSignalNames string "packetReceivedFromLower"

space-separated list of inbound packet signals to subscribe to

ue.pcapRecorder.dumpProtocols string "ethernetmac ppp ieee80211mac"

space-separated list of protocol names as defined in the Protocol class

ue.pcapRecorder.packetFilter object "*"

which packets are considered, matches all packets by default

ue.pcapRecorder.helpers string ""

usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper"

ue.pcapRecorder.alwaysFlush bool false

flush the pcapFile after each write to ensure that all packets are captured in case of a crash

ue.pcapRecorder.displayStringTextFormat string "rec: %n pks"

Source code

network ExtUeAppMecAppExample
{
    parameters:

        double playgroundSizeX @unit(m); // x size of the area the nodes are in (in meters)
        double playgroundSizeY @unit(m); // y size of the area the nodes are in (in meters)
        double playgroundSizeZ @unit(m); // z size of the area the nodes are in (in meters)
        @display("bgb=805,500");

    submodules:
        routingRecorder: RoutingTableRecorder {
            @display("p=690,104;is=s");
        }
        configurator: Ipv4NetworkConfigurator {
            @display("p=556,34");
        }
        channelControl: LteChannelControl {
            @display("p=690,24;is=s");
        }
        binder: Binder {
            @display("p=474,34;is=s");
        }
        carrierAggregation: CarrierAggregation {
            @display("p=368,34;is=s");
        }
        upf: Upf {
            @display("p=420,259");
        }
        iUpf: Upf {
            @display("p=277,259");
        }
        gNodeB1: gNodeB {
            @display("p=137,260;is=vl");
        }

        //# MEC modules
        mecHost1: MECHost {
            @display("p=277,158;is=l");
        }

        mecOrchestrator: MecOrchestrator {
            @display("p=520,158;is=l");
        }

        ualcmp: UALCMP {
            @display("p=420,157;i=device/smallrouter");
        }

        ue: NRUe {
            @display("p=51,259");
        }

    connections allowunconnected:

        gNodeB1.ppp <--> Eth10G <--> iUpf.pppg++;
        iUpf.pppg++ <--> Eth10G <--> upf.pppg++;

	    //#	mec
        mecHost1.ppp++ <--> Eth10G <--> iUpf.pppg++;
        upf.filterGate <--> Eth10G <--> ualcmp.ppp++;

        ualcmp.toMecOrchestrator --> mecOrchestrator.fromUALCMP;
        ualcmp.fromMecOrchestrator <-- mecOrchestrator.toUALCMP;
}
File: emulation/mec/extUeAppMecApp/ExtUeAppMecAppExample.ned