Orchestra: handle case where ORCHESTRA_UNICAST_PERIOD is smaller than the network size
This commit is contained in:
parent
366231f601
commit
287b4767e3
|
@ -85,9 +85,15 @@ add_uc_link(const linkaddr_t *linkaddr)
|
|||
{
|
||||
if(linkaddr != NULL) {
|
||||
uint16_t timeslot = get_node_timeslot(linkaddr);
|
||||
tsch_schedule_add_link(sf_unicast,
|
||||
ORCHESTRA_UNICAST_SENDER_BASED ? LINK_OPTION_RX : LINK_OPTION_TX | UNICAST_SLOT_SHARED_FLAG,
|
||||
LINK_TYPE_NORMAL, &tsch_broadcast_address,
|
||||
uint8_t link_options = ORCHESTRA_UNICAST_SENDER_BASED ? LINK_OPTION_RX : LINK_OPTION_TX | UNICAST_SLOT_SHARED_FLAG;
|
||||
|
||||
if(timeslot == get_node_timeslot(&linkaddr_node_addr)) {
|
||||
/* This is also our timeslot, add necessary flags */
|
||||
link_options |= ORCHESTRA_UNICAST_SENDER_BASED ? LINK_OPTION_TX | UNICAST_SLOT_SHARED_FLAG: LINK_OPTION_RX;
|
||||
}
|
||||
|
||||
/* Add/update link */
|
||||
tsch_schedule_add_link(sf_unicast, link_options, LINK_TYPE_NORMAL, &tsch_broadcast_address,
|
||||
timeslot, channel_offset);
|
||||
}
|
||||
}
|
||||
|
@ -123,8 +129,18 @@ remove_uc_link(const linkaddr_t *linkaddr)
|
|||
}
|
||||
item = nbr_table_next(nbr_routes, item);
|
||||
}
|
||||
|
||||
/* Do we need this timeslot? */
|
||||
if(timeslot == get_node_timeslot(&linkaddr_node_addr)) {
|
||||
/* This is our link, keep it but update the link options */
|
||||
uint8_t link_options = ORCHESTRA_UNICAST_SENDER_BASED ? LINK_OPTION_TX | UNICAST_SLOT_SHARED_FLAG: LINK_OPTION_RX;
|
||||
tsch_schedule_add_link(sf_unicast, link_options, LINK_TYPE_NORMAL, &tsch_broadcast_address,
|
||||
timeslot, channel_offset);
|
||||
} else {
|
||||
/* Remove link */
|
||||
tsch_schedule_remove_link(sf_unicast, l);
|
||||
}
|
||||
}
|
||||
/*---------------------------------------------------------------------------*/
|
||||
static void
|
||||
child_added(const linkaddr_t *linkaddr)
|
||||
|
|
Loading…
Reference in a new issue