# # NEPI, a framework to manage network experiments # Copyright (C) 2014 INRIA # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License version 2 as # published by the Free Software Foundation; # # 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 General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # from nepi.execution.attribute import Attribute, Flags, Types from nepi.execution.trace import Trace, TraceAttr from nepi.execution.resource import ResourceManager, clsinit_copy, \ ResourceState from nepi.resources.ns3.ns3arpl3protocol import NS3BaseArpL3Protocol @clsinit_copy class NS3ArpL3Protocol(NS3BaseArpL3Protocol): _rtype = "ns3::ArpL3Protocol" @classmethod def _register_attributes(cls): attr_requestjitter = Attribute("RequestJitter", "The jitter in ms a node is allowed to wait before sending an ARP request. Some jitter aims to prevent collisions. By default, the model will wait for a duration in ms defined by a uniform random-variable between 0 and RequestJitter", type = Types.String, default = "ns3::UniformRandomVariable[Min=0.0|Max=10.0]", allowed = None, range = None, flags = Flags.Reserved | Flags.Construct) cls._register_attribute(attr_requestjitter) @classmethod def _register_traces(cls): drop = Trace("Drop", "Packet dropped because not enough room in pending queue for a specific cache entry.") cls._register_trace(drop) def __init__(self, ec, guid): super(NS3ArpL3Protocol, self).__init__(ec, guid) self._home = "ns3-arp-l3protocol-%s" % self.guid