Flooding

Package: inet.networklayer.flooding

Flooding

simple module

A simple flooding protocol for network-level broadcast.

This implementation uses plain flooding, i.e. it "remembers" (stores) already broadcasted messages in a list and does not rebroadcast them again, if it gets another copy of that message.

The maximum number of entries for that list can be defined in the .ini file (bcMaxEntries parameter) as well as the time after which an entry is deleted (bcDelTime parameter).

If you prefere a memory-less version you should set to false the plainFlooding bool parameter.

Author: Daniel Willkomm

ported to Mixim 2.0 by Theodoros Kapourniotis

Inheritance diagram

The following diagram shows inheritance relationships for this type. Unresolved types are missing from the diagram.

Extends

Name Type Description
NetworkProtocolBase simple module

Module base for different network protocols.

Parameters

Name Type Default value Description
interfaceTableModule string
headerLength int 96b

length of the network packet header (in bits)

plainFlooding bool true

flag whether to use plain flooding

bcMaxEntries int 100

Max number of entries in the list of already broadcasted messages

bcDelTime double 100 s

Time after which an entry for an already broadcasted msg can be deleted

defaultTtl int 10

Default time-to-live (ttl) used for this module expressed in number of hops.

Properties

Name Value Description
display i=block/fork
class Flooding

Gates

Name Direction Size Description
transportIn input
transportOut output
queueIn input
queueOut output

Signals

Name Type Unit
packetReceivedFromUpper cPacket
packetReceivedFromLower cPacket
packetDropped cPacket
packetSentToLower cPacket
packetSentToUpper cPacket

Direct method calls (observed)

call tofunctioninfo
MessageDispatcherinet::MessageDispatcher::arrivedarrived
MessageDispatcherinet::MessageDispatcher::handleRegisterProtocolhandleRegisterProtocol
MessageDispatcherinet::MessageDispatcher::handleRegisterServicehandleRegisterService
InterfaceTableinet::InterfaceTable::findFirstNonLoopbackInterfacefindFirstNonLoopbackInterface

Called methods (observed)

functioninfocall from
inet::Flooding::handleRegisterProtocolhandleRegisterProtocolMessageDispatcher
inet::Flooding::handleRegisterServicehandleRegisterServiceMessageDispatcher

Incoming messages (observed)

gatemsgkindctrlsrcModuletags
queueInPacket0EthernetEncapsulationDispatchProtocolReq, InterfaceInd, MacAddressInd, PacketProtocolTag
transportInPacket0PingAppDispatchProtocolReq, L3AddressReq, PacketProtocolTag, SocketReq
transportInPacket0EchoProtocolDispatchProtocolReq, L3AddressReq, PacketProtocolTag
transportInRequest1L3SocketBindCommandPingAppDispatchProtocolReq, SocketReq

Outgoing messages (observed)

gatemsgkindctrldestModuletags
queueOutPacket0EthernetEncapsulationDispatchProtocolInd, DispatchProtocolReq, InterfaceReq, MacAddressReq, PacketProtocolTag, InterfaceInd?, L3AddressReq?, MacAddressInd?, SocketReq?
transportOutPacket0PingAppDispatchProtocolReq, HopLimitInd, InterfaceInd, L3AddressInd, MacAddressInd, NetworkProtocolInd, PacketProtocolTag, SocketInd
transportOutPacket0EchoProtocolDispatchProtocolReq, HopLimitInd, InterfaceInd, L3AddressInd, MacAddressInd, NetworkProtocolInd, PacketProtocolTag

Packet operations (observed)

chunkTypepacketAction
FloodingHeaderinsertAtFront, peekAtFront, popAtFront, removeAtFront

Shared Tagging operations (observed)

tagTypetagAction
DispatchProtocolIndaddTagIfAbsent
DispatchProtocolReqaddTagIfAbsent
HopLimitIndaddTagIfAbsent
HopLimitReqremoveTagIfPresent
InterfaceReqaddTagIfAbsent
L3AddressIndaddTagIfAbsent, getTag
L3AddressReqfindTag
MacAddressReqaddTagIfAbsent
NetworkProtocolIndaddTagIfAbsent
PacketProtocolTagaddTagIfAbsent, getTag
SocketIndaddTagIfAbsent
SocketReqgetTag

Tagging operations (observed)

tagTypetagAction
inet::Ipv4InterfaceDatafindTag
inet::Ipv6InterfaceDatafindTag
inet::NextHopInterfaceDatafindTag

Source code

//
// A simple flooding protocol for network-level broadcast.
//
// This implementation uses plain flooding, i.e. it "remembers"
// (stores) already broadcasted messages in a list and does not
// rebroadcast them again, if it gets another copy of that message.
//
// The maximum number of entries for that list can be defined in the
// .ini file (bcMaxEntries parameter) as well as the time after which an entry
// is deleted (bcDelTime parameter).
//
// If you prefere a memory-less version you should set to false the
// plainFlooding bool parameter.
//
// @author Daniel Willkomm
//
// ported to Mixim 2.0 by Theodoros Kapourniotis
//
simple Flooding extends NetworkProtocolBase like INetworkProtocol
{
    parameters:
        @display("i=block/fork");
        int headerLength @unit(b) = default(96b); // length of the network packet header (in bits)
        bool plainFlooding = default(true); // flag whether to use plain flooding
        // Max number of entries in the list of already broadcasted messages
        int bcMaxEntries = default(100);
        // Time after which an entry for an already broadcasted msg can be deleted
        double bcDelTime @unit(s) = default(100 s);
        int defaultTtl = default(10); // Default time-to-live (ttl) used for this module expressed in  number of hops.
        @class(Flooding);
}

File: src/inet/networklayer/flooding/Flooding.ned