Package: simu5g.emulation.mec.extMecApp
ExtMecAppExample
network(no description)
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 ExtMecAppExample { 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/extMecApp/ExtMecAppExample.ned