54 #if UIP_MAX_ROUTES != 0 56 #if ORCHESTRA_UNICAST_SENDER_BASED && ORCHESTRA_COLLISION_FREE_HASH 57 #define UNICAST_SLOT_SHARED_FLAG ((ORCHESTRA_UNICAST_PERIOD < (ORCHESTRA_MAX_HASH + 1)) ? LINK_OPTION_SHARED : 0) 59 #define UNICAST_SLOT_SHARED_FLAG LINK_OPTION_SHARED 62 static uint16_t slotframe_handle = 0;
63 static uint16_t channel_offset = 0;
68 get_node_timeslot(
const linkaddr_t *
addr)
70 if(addr != NULL && ORCHESTRA_UNICAST_PERIOD > 0) {
71 return ORCHESTRA_LINKADDR_HASH(addr) % ORCHESTRA_UNICAST_PERIOD;
78 neighbor_has_uc_link(
const linkaddr_t *linkaddr)
81 if((orchestra_parent_knows_us || !ORCHESTRA_UNICAST_SENDER_BASED)
85 if(nbr_table_get_from_lladdr(nbr_routes, (linkaddr_t *)linkaddr) != NULL) {
93 add_uc_link(
const linkaddr_t *linkaddr)
95 if(linkaddr != NULL) {
96 uint16_t timeslot = get_node_timeslot(linkaddr);
97 uint8_t link_options = ORCHESTRA_UNICAST_SENDER_BASED ? LINK_OPTION_RX : LINK_OPTION_TX | UNICAST_SLOT_SHARED_FLAG;
101 link_options |= ORCHESTRA_UNICAST_SENDER_BASED ? LINK_OPTION_TX | UNICAST_SLOT_SHARED_FLAG: LINK_OPTION_RX;
106 timeslot, channel_offset);
111 remove_uc_link(
const linkaddr_t *linkaddr)
116 if(linkaddr == NULL) {
120 timeslot = get_node_timeslot(linkaddr);
126 if(timeslot == get_node_timeslot(&orchestra_parent_linkaddr)) {
132 nbr_table_item_t *item = nbr_table_head(nbr_routes);
133 while(item != NULL) {
134 linkaddr_t *addr = nbr_table_get_lladdr(nbr_routes, item);
135 if(timeslot == get_node_timeslot(addr)) {
139 item = nbr_table_next(nbr_routes, item);
145 uint8_t link_options = ORCHESTRA_UNICAST_SENDER_BASED ? LINK_OPTION_TX | UNICAST_SLOT_SHARED_FLAG: LINK_OPTION_RX;
147 timeslot, channel_offset);
155 child_added(
const linkaddr_t *linkaddr)
157 add_uc_link(linkaddr);
161 child_removed(
const linkaddr_t *linkaddr)
163 remove_uc_link(linkaddr);
167 select_packet(uint16_t *slotframe, uint16_t *timeslot)
170 const linkaddr_t *dest = packetbuf_addr(PACKETBUF_ADDR_RECEIVER);
171 if(packetbuf_attr(PACKETBUF_ATTR_FRAME_TYPE) == FRAME802154_DATAFRAME
172 && neighbor_has_uc_link(dest)) {
173 if(slotframe != NULL) {
174 *slotframe = slotframe_handle;
176 if(timeslot != NULL) {
177 *timeslot = ORCHESTRA_UNICAST_SENDER_BASED ? get_node_timeslot(&
linkaddr_node_addr) : get_node_timeslot(dest);
188 const linkaddr_t *old_addr = old != NULL ? &old->addr : NULL;
189 const linkaddr_t *new_addr =
new != NULL ? &
new->addr : NULL;
190 if(new_addr != NULL) {
195 remove_uc_link(old_addr);
196 add_uc_link(new_addr);
201 init(uint16_t sf_handle)
203 slotframe_handle = sf_handle;
204 channel_offset = sf_handle;
209 ORCHESTRA_UNICAST_SENDER_BASED ? LINK_OPTION_TX | UNICAST_SLOT_SHARED_FLAG: LINK_OPTION_RX,
210 LINK_TYPE_NORMAL, &tsch_broadcast_address,
211 timeslot, channel_offset);
214 struct orchestra_rule unicast_per_neighbor_rpl_storing = {
static uip_ds6_addr_t * addr
Pointer to a nbr cache entry.
TSCH neighbor information.
802.15.4e slotframe (contains links)
struct tsch_slotframe * tsch_schedule_add_slotframe(uint16_t handle, uint16_t size)
Creates and adds a new slotframe.
struct tsch_link * tsch_schedule_get_link_by_timeslot(struct tsch_slotframe *slotframe, uint16_t timeslot)
Looks within a slotframe for a link with a given timeslot.
const linkaddr_t linkaddr_null
The null link-layer address.
linkaddr_t linkaddr_node_addr
The link-layer address of the node.
Routing driver header file
int tsch_schedule_remove_link(struct tsch_slotframe *slotframe, struct tsch_link *l)
Removes a link.
struct tsch_link * tsch_schedule_add_link(struct tsch_slotframe *slotframe, uint8_t link_options, enum link_type link_type, const linkaddr_t *address, uint16_t timeslot, uint16_t channel_offset)
Adds a link to a slotframe.
void linkaddr_copy(linkaddr_t *dest, const linkaddr_t *src)
Copy a link-layer address.
int linkaddr_cmp(const linkaddr_t *addr1, const linkaddr_t *addr2)
Compare two link-layer addresses.
Header file for routing table manipulation.
An IEEE 802.15.4-2015 TSCH link (also called cell or slot)
Header file for the Packet buffer (packetbuf) management