InterfaceTable.ned

NED File src/inet/networklayer/common/InterfaceTable.ned

Name Type Description
InterfaceTable simple module

Keeps the table of network interfaces.

Source code

//
// Copyright (C) 2005 Andras Varga
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this program; if not, see <http://www.gnu.org/licenses/>.


package inet.networklayer.common;

//
// Keeps the table of network interfaces.
//
// Interfaces are dynamically registered by the corresponding L2 modules, e.g.
// ~PPPInterface. In addition to registered interfaces, a loopback interface
// will also be created. This table only contains protocol-independent
// properties of interfaces -- IPv4 or IPv6 specific per-interface data
// (addresses etc) are kept in ~IPv4RoutingTable and ~IPv6RoutingTable.
// Must be named as "interfaceTable".
//
// This module has no gates; all functionality can be accessed via member
// functions of the C++ module class. For detailed info, please see the C++
// documentation of the class (Doxygen).
//
// @author: Andras Varga
//
simple InterfaceTable
{
    parameters:
        bool displayAddresses = default(false);  // whether to display IP addresses on links
        @display("i=block/table");
        @signal[NF_INTERFACE_CREATED](type=inet::InterfaceEntry);
        @signal[NF_INTERFACE_DELETED](type=inet::InterfaceEntry);
        @signal[NF_INTERFACE_STATE_CHANGED](type=inet::InterfaceEntryChangeDetails);
        @signal[NF_INTERFACE_CONFIG_CHANGED](type=inet::InterfaceEntryChangeDetails);
        @signal[NF_INTERFACE_IPv4CONFIG_CHANGED](type=inet::InterfaceEntryChangeDetails);
        @signal[NF_INTERFACE_IPv6CONFIG_CHANGED](type=inet::InterfaceEntryChangeDetails);
        @signal[NF_INTERFACE_GENERICNETWORKPROTOCOLCONFIG_CHANGED](type=inet::InterfaceEntryChangeDetails);
        @signal[NF_IPv4_MCAST_JOIN](type=inet::IPv4MulticastGroupInfo);
        @signal[NF_IPv4_MCAST_LEAVE](type=inet::IPv4MulticastGroupInfo);
        @signal[NF_IPv4_MCAST_CHANGE](type=inet::IPv4MulticastGroupSourceInfo);
        @signal[NF_IPv4_MCAST_REGISTERED](type=inet::IPv4MulticastGroupInfo);
        @signal[NF_IPv4_MCAST_UNREGISTERED](type=inet::IPv4MulticastGroupInfo);
        @signal[NF_IPv6_MCAST_JOIN](type=inet::IPv6MulticastGroupInfo);
        @signal[NF_IPv6_MCAST_LEAVE](type=inet::IPv6MulticastGroupInfo);
}