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
|
2021-03-19 23:54:24 +00:00
|
|
|
from pathlib import Path
|
2020-06-12 17:52:01 +01:00
|
|
|
from typing import Set
|
2018-03-26 18:27:39 +01:00
|
|
|
|
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
|
|
|
|
2021-04-22 05:09:35 +01:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
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
|
2020-06-12 17:52:01 +01:00
|
|
|
name: str = "emane_tdma"
|
2018-03-29 21:32:06 +01:00
|
|
|
|
|
|
|
# mac configuration
|
2020-06-12 17:52:01 +01:00
|
|
|
mac_library: str = "tdmaeventschedulerradiomodel"
|
|
|
|
mac_xml: str = "tdmaeventschedulerradiomodel.xml"
|
2018-03-30 20:08:33 +01:00
|
|
|
|
|
|
|
# add custom schedule options and ignore it when writing emane xml
|
2020-06-12 17:52:01 +01:00
|
|
|
schedule_name: str = "schedule"
|
2021-03-19 23:54:24 +00:00
|
|
|
default_schedule: Path = (
|
|
|
|
constants.CORE_DATA_DIR / "examples" / "tdma" / "schedule.xml"
|
2019-09-10 23:10:24 +01:00
|
|
|
)
|
2020-06-12 17:52:01 +01:00
|
|
|
config_ignore: Set[str] = {schedule_name}
|
2016-09-15 01:15:43 +01:00
|
|
|
|
2019-04-08 17:49:37 +01:00
|
|
|
@classmethod
|
2021-03-19 23:54:24 +00:00
|
|
|
def load(cls, emane_prefix: Path) -> None:
|
|
|
|
cls.mac_defaults["pcrcurveuri"] = str(
|
|
|
|
emane_prefix
|
|
|
|
/ "share/emane/xml/models/mac/tdmaeventscheduler/tdmabasemodelpcr.xml"
|
2019-04-08 17:49:37 +01:00
|
|
|
)
|
2019-10-23 17:51:52 +01:00
|
|
|
super().load(emane_prefix)
|
2021-03-19 23:54:24 +00:00
|
|
|
config_item = Configuration(
|
2021-03-31 19:13:40 +01:00
|
|
|
id=cls.schedule_name,
|
|
|
|
type=ConfigDataTypes.STRING,
|
2021-03-19 23:54:24 +00:00
|
|
|
default=str(cls.default_schedule),
|
|
|
|
label="TDMA schedule file (core)",
|
2019-04-08 17:49:37 +01:00
|
|
|
)
|
2021-03-19 23:54:24 +00:00
|
|
|
cls.mac_config.insert(0, config_item)
|
2019-04-08 17:49:37 +01:00
|
|
|
|
2020-01-15 00:27:08 +00:00
|
|
|
def post_startup(self) -> None:
|
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
|
2021-04-22 05:09:35 +01:00
|
|
|
logger.info(
|
2019-09-10 23:10:24 +01:00
|
|
|
"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)
|