mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #2625 from cgundogan/rpl_remove_global_root_indication
rpl: remove global variable indicating the root node
This commit is contained in:
commit
51ff5e056c
@ -35,9 +35,6 @@ static char addr_str[IPV6_MAX_ADDR_STR_LEN];
|
|||||||
#endif
|
#endif
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
/* Identification variables */
|
|
||||||
static char i_am_root;
|
|
||||||
|
|
||||||
/* in send buffer we need space for LL_HDR */
|
/* in send buffer we need space for LL_HDR */
|
||||||
static uint8_t rpl_send_buffer[BUFFER_SIZE];
|
static uint8_t rpl_send_buffer[BUFFER_SIZE];
|
||||||
|
|
||||||
@ -244,7 +241,6 @@ void rpl_init_root(rpl_options_t *rpl_opts)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
i_am_root = 1;
|
|
||||||
trickle_start(rpl_process_pid, &dodag->trickle, RPL_MSG_TYPE_TRICKLE_INTERVAL,
|
trickle_start(rpl_process_pid, &dodag->trickle, RPL_MSG_TYPE_TRICKLE_INTERVAL,
|
||||||
RPL_MSG_TYPE_TRICKLE_CALLBACK, (1 << dodag->dio_min), dodag->dio_interval_doubling,
|
RPL_MSG_TYPE_TRICKLE_CALLBACK, (1 << dodag->dio_min), dodag->dio_interval_doubling,
|
||||||
dodag->dio_redundancy);
|
dodag->dio_redundancy);
|
||||||
@ -252,9 +248,19 @@ void rpl_init_root(rpl_options_t *rpl_opts)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* TODO: this function is used by the ip layer for source routing (non-storing mode)
|
||||||
|
* to determine if the node is root and change the dodag direction (upwards -> downwards).
|
||||||
|
* This is a hack and needs to be refactored when the new network stack is ready.
|
||||||
|
*/
|
||||||
uint8_t rpl_is_root(void)
|
uint8_t rpl_is_root(void)
|
||||||
{
|
{
|
||||||
return i_am_root;
|
rpl_dodag_t *dodag, *end;
|
||||||
|
for (dodag = rpl_dodags, end = dodag + RPL_MAX_DODAGS; dodag < end; dodag++) {
|
||||||
|
if (dodag->node_status == ROOT_NODE) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void rpl_send_DIO(rpl_dodag_t *mydodag, ipv6_addr_t *destination)
|
void rpl_send_DIO(rpl_dodag_t *mydodag, ipv6_addr_t *destination)
|
||||||
@ -345,12 +351,12 @@ void rpl_send_DAO(rpl_dodag_t *my_dodag, ipv6_addr_t *destination, uint8_t lifet
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (i_am_root) {
|
if (my_dodag == NULL) {
|
||||||
|
DEBUGF("send_DAO: I have no my_dodag\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (my_dodag == NULL) {
|
if (my_dodag->node_status == ROOT_NODE) {
|
||||||
DEBUGF("send_DAO: I have no my_dodag\n");
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -754,13 +760,9 @@ void rpl_recv_DIO(void)
|
|||||||
void rpl_recv_DAO(void)
|
void rpl_recv_DAO(void)
|
||||||
{
|
{
|
||||||
#if RPL_DEFAULT_MOP == RPL_MOP_NON_STORING_MODE
|
#if RPL_DEFAULT_MOP == RPL_MOP_NON_STORING_MODE
|
||||||
|
|
||||||
if (!i_am_root) {
|
|
||||||
DEBUGF("[Error] something went wrong - got a DAO.\n");
|
DEBUGF("[Error] something went wrong - got a DAO.\n");
|
||||||
return;
|
return;
|
||||||
}
|
#else
|
||||||
|
|
||||||
#endif
|
|
||||||
ipv6_buf = get_rpl_ipv6_buf();
|
ipv6_buf = get_rpl_ipv6_buf();
|
||||||
rpl_dao_buf = get_rpl_dao_buf();
|
rpl_dao_buf = get_rpl_dao_buf();
|
||||||
DEBUG("instance %04X ", rpl_dao_buf->rpl_instanceid);
|
DEBUG("instance %04X ", rpl_dao_buf->rpl_instanceid);
|
||||||
@ -854,6 +856,7 @@ void rpl_recv_DAO(void)
|
|||||||
RPL_COUNTER_INCREMENT(my_dodag->dao_seq);
|
RPL_COUNTER_INCREMENT(my_dodag->dao_seq);
|
||||||
rpl_delay_dao(my_dodag);
|
rpl_delay_dao(my_dodag);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void rpl_recv_DIS(void)
|
void rpl_recv_DIS(void)
|
||||||
|
Loading…
Reference in New Issue
Block a user