1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

Merge pull request #4123 from cgundogan/pr/nc/xtimer_rtr_timeout

nc: user xtimer for gnrc_ipv6_nc_t::rtr_timeout
This commit is contained in:
Cenk Gündoğan 2015-10-26 15:46:01 +01:00
commit 2065537368
3 changed files with 7 additions and 4 deletions

View File

@ -128,7 +128,8 @@ typedef struct {
uint8_t l2_addr_len; /**< Length of gnrc_ipv6_nc_t::l2_addr */ uint8_t l2_addr_len; /**< Length of gnrc_ipv6_nc_t::l2_addr */
uint8_t flags; /**< Flags as defined above */ uint8_t flags; /**< Flags as defined above */
kernel_pid_t iface; /**< PID to the interface where the neighbor is */ kernel_pid_t iface; /**< PID to the interface where the neighbor is */
vtimer_t rtr_timeout; /**< timeout timer for router flag */ xtimer_t rtr_timeout; /**< timeout timer for router flag */
msg_t rtr_timeout_msg; /**< msg_t for gnrc_ipv6_nc_t::rtr_timeout */
/** /**
* @brief (Re)Transmission timer for neighbor solicitations of this entry and * @brief (Re)Transmission timer for neighbor solicitations of this entry and

View File

@ -133,6 +133,9 @@ gnrc_ipv6_nc_t *gnrc_ipv6_nc_add(kernel_pid_t iface, const ipv6_addr_t *ipv6_add
free_entry->type_timeout_msg.content.ptr = (char *) free_entry; free_entry->type_timeout_msg.content.ptr = (char *) free_entry;
#endif #endif
free_entry->rtr_timeout_msg.type = GNRC_NDP_MSG_RTR_TIMEOUT;
free_entry->rtr_timeout_msg.content.ptr = (char *) free_entry;
return free_entry; return free_entry;
} }

View File

@ -518,9 +518,8 @@ void gnrc_ndp_rtr_adv_handle(kernel_pid_t iface, gnrc_pktsnip_t *pkt, ipv6_hdr_t
#ifdef MODULE_GNRC_SIXLOWPAN_ND #ifdef MODULE_GNRC_SIXLOWPAN_ND
next_rtr_sol = ltime; next_rtr_sol = ltime;
#endif #endif
vtimer_remove(&nc_entry->rtr_timeout); xtimer_set_msg(&nc_entry->rtr_timeout, (ltime * SEC_IN_USEC),
vtimer_set_msg(&nc_entry->rtr_timeout, timex_set(ltime, 0), &nc_entry->rtr_timeout_msg, thread_getpid());
thread_getpid(), GNRC_NDP_MSG_RTR_TIMEOUT, nc_entry);
} }
/* set current hop limit from message if available */ /* set current hop limit from message if available */
if (rtr_adv->cur_hl != 0) { if (rtr_adv->cur_hl != 0) {