2017-04-25 16:45:34 +01:00
|
|
|
"""
|
2016-09-15 01:15:43 +01:00
|
|
|
tdma.py: EMANE TDMA model bindings for CORE
|
2017-04-25 16:45:34 +01:00
|
|
|
"""
|
|
|
|
|
2019-02-16 17:50:19 +00:00
|
|
|
import logging
|
2018-03-26 18:27:39 +01:00
|
|
|
import os
|
|
|
|
|
2019-04-30 07:31:47 +01:00
|
|
|
from core import constants, utils
|
|
|
|
from core.config import Configuration
|
2018-03-29 22:38:32 +01:00
|
|
|
from core.emane import emanemodel
|
2019-04-30 07:31:47 +01:00
|
|
|
from core.emulator.enumerations import ConfigDataTypes
|
2016-09-15 01:15:43 +01:00
|
|
|
|
|
|
|
|
2018-03-29 22:38:32 +01:00
|
|
|
class EmaneTdmaModel(emanemodel.EmaneModel):
|
2016-09-15 01:15:43 +01:00
|
|
|
# model name
|
2017-04-25 16:45:34 +01:00
|
|
|
name = "emane_tdma"
|
2018-03-29 21:32:06 +01:00
|
|
|
|
|
|
|
# mac configuration
|
2018-03-30 20:08:33 +01:00
|
|
|
mac_library = "tdmaeventschedulerradiomodel"
|
2019-04-08 17:49:37 +01:00
|
|
|
mac_xml = "tdmaeventschedulerradiomodel.xml"
|
2018-03-30 20:08:33 +01:00
|
|
|
|
|
|
|
# add custom schedule options and ignore it when writing emane xml
|
2018-03-26 18:27:39 +01:00
|
|
|
schedule_name = "schedule"
|
2019-09-10 23:10:24 +01:00
|
|
|
default_schedule = os.path.join(
|
|
|
|
constants.CORE_DATA_DIR, "examples", "tdma", "schedule.xml"
|
|
|
|
)
|
2018-03-29 21:32:06 +01:00
|
|
|
config_ignore = {schedule_name}
|
2016-09-15 01:15:43 +01:00
|
|
|
|
2019-04-08 17:49:37 +01:00
|
|
|
@classmethod
|
|
|
|
def load(cls, emane_prefix):
|
|
|
|
cls.mac_defaults["pcrcurveuri"] = os.path.join(
|
|
|
|
emane_prefix,
|
2019-09-10 23:10:24 +01:00
|
|
|
"share/emane/xml/models/mac/tdmaeventscheduler/tdmabasemodelpcr.xml",
|
2019-04-08 17:49:37 +01:00
|
|
|
)
|
|
|
|
super(EmaneTdmaModel, cls).load(emane_prefix)
|
|
|
|
cls.mac_config.insert(
|
|
|
|
0,
|
|
|
|
Configuration(
|
|
|
|
_id=cls.schedule_name,
|
|
|
|
_type=ConfigDataTypes.STRING,
|
|
|
|
default=cls.default_schedule,
|
2019-09-10 23:10:24 +01:00
|
|
|
label="TDMA schedule file (core)",
|
|
|
|
),
|
2019-04-08 17:49:37 +01:00
|
|
|
)
|
|
|
|
|
2018-06-11 20:26:51 +01:00
|
|
|
def post_startup(self):
|
2018-03-26 18:27:39 +01:00
|
|
|
"""
|
|
|
|
Logic to execute after the emane manager is finished with startup.
|
|
|
|
|
|
|
|
:return: nothing
|
|
|
|
"""
|
|
|
|
# get configured schedule
|
2019-04-30 07:31:47 +01:00
|
|
|
config = self.session.emane.get_configs(node_id=self.id, config_type=self.name)
|
2018-06-06 22:51:45 +01:00
|
|
|
if not config:
|
2018-03-26 06:08:22 +01:00
|
|
|
return
|
2018-06-06 22:51:45 +01:00
|
|
|
schedule = config[self.schedule_name]
|
2018-03-28 21:58:49 +01:00
|
|
|
|
2018-06-11 20:26:51 +01:00
|
|
|
# get the set event device
|
|
|
|
event_device = self.session.emane.event_device
|
2018-03-26 18:27:39 +01:00
|
|
|
|
|
|
|
# initiate tdma schedule
|
2019-09-10 23:10:24 +01:00
|
|
|
logging.info(
|
|
|
|
"setting up tdma schedule: schedule(%s) device(%s)", schedule, event_device
|
|
|
|
)
|
2019-10-18 18:33:31 +01:00
|
|
|
args = f"emaneevent-tdmaschedule -i {event_device} {schedule}"
|
2019-10-21 18:32:42 +01:00
|
|
|
utils.cmd(args)
|