From 7c6b36703572bc958e6a5cd1174f09f3a8671b8f Mon Sep 17 00:00:00 2001 From: Benjamin Valentin Date: Thu, 19 Oct 2023 19:45:34 +0200 Subject: [PATCH 1/2] nib/_nib-6ln: bail out early if address is no longer assigned --- .../gnrc/network_layer/ipv6/nib/_nib-6ln.c | 58 ++++++++++--------- 1 file changed, 31 insertions(+), 27 deletions(-) diff --git a/sys/net/gnrc/network_layer/ipv6/nib/_nib-6ln.c b/sys/net/gnrc/network_layer/ipv6/nib/_nib-6ln.c index d15765a3ee41..816dae35b0b1 100644 --- a/sys/net/gnrc/network_layer/ipv6/nib/_nib-6ln.c +++ b/sys/net/gnrc/network_layer/ipv6/nib/_nib-6ln.c @@ -185,12 +185,19 @@ void _handle_rereg_address(const ipv6_addr_t *addr) { gnrc_netif_t *netif = gnrc_netif_get_by_ipv6_addr(addr); + if (netif == NULL) { + DEBUG("nib: Couldn't re-register %s, address wasn't assigned to any " + "interface anymore.\n", + ipv6_addr_to_str(addr_str, addr, sizeof(addr_str))); + return; + } + gnrc_netif_acquire(netif); _nib_dr_entry_t *router = _nib_drl_get(NULL, netif->pid); const bool router_reachable = (router != NULL) && _is_reachable(router->next_hop); - if (router_reachable && (netif != NULL)) { + if (router_reachable) { assert((unsigned)netif->pid == _nib_onl_get_if(router->next_hop)); DEBUG("nib: Re-registering %s", ipv6_addr_to_str(addr_str, addr, sizeof(addr_str))); @@ -200,39 +207,36 @@ void _handle_rereg_address(const ipv6_addr_t *addr) _snd_ns(&router->next_hop->ipv6, netif, addr, &router->next_hop->ipv6); } else { - DEBUG("nib: Couldn't re-register %s, no current router found or address " - "wasn't assigned to any interface anymore.\n", + DEBUG("nib: Couldn't re-register %s, no current router found.\n", ipv6_addr_to_str(addr_str, addr, sizeof(addr_str))); } - if (netif != NULL) { - int idx = gnrc_netif_ipv6_addr_idx(netif, addr); - if (idx < 0) { - DEBUG("nib: %s is not assigned to interface %d anymore.\n", - ipv6_addr_to_str(addr_str, addr, sizeof(addr_str)), - netif->pid); - } - else if (router_reachable && - (_is_valid(netif, idx) || (_is_tentative(netif, idx) && - (gnrc_netif_ipv6_addr_dad_trans(netif, idx) < - SIXLOWPAN_ND_REG_TRANSMIT_NUMOF)))) { - uint32_t retrans_time; + int idx = gnrc_netif_ipv6_addr_idx(netif, addr); + if (idx < 0) { + DEBUG("nib: %s is not assigned to interface %d anymore.\n", + ipv6_addr_to_str(addr_str, addr, sizeof(addr_str)), + netif->pid); + } + else if (router_reachable && + (_is_valid(netif, idx) || (_is_tentative(netif, idx) && + (gnrc_netif_ipv6_addr_dad_trans(netif, idx) < + SIXLOWPAN_ND_REG_TRANSMIT_NUMOF)))) { + uint32_t retrans_time; - if (_is_valid(netif, idx)) { - retrans_time = SIXLOWPAN_ND_MAX_RS_SEC_INTERVAL * MS_PER_SEC; - } - else { - retrans_time = netif->ipv6.retrans_time; - /* increment encoded retransmission count */ - netif->ipv6.addrs_flags[idx]++; - } - _evtimer_add(&netif->ipv6.addrs[idx], GNRC_IPV6_NIB_REREG_ADDRESS, - &netif->ipv6.addrs_timers[idx], retrans_time); + if (_is_valid(netif, idx)) { + retrans_time = SIXLOWPAN_ND_MAX_RS_SEC_INTERVAL * MS_PER_SEC; } else { - netif->ipv6.rs_sent = 0; - _handle_search_rtr(netif); + retrans_time = netif->ipv6.retrans_time; + /* increment encoded retransmission count */ + netif->ipv6.addrs_flags[idx]++; } + _evtimer_add(&netif->ipv6.addrs[idx], GNRC_IPV6_NIB_REREG_ADDRESS, + &netif->ipv6.addrs_timers[idx], retrans_time); + } + else { + netif->ipv6.rs_sent = 0; + _handle_search_rtr(netif); } gnrc_netif_release(netif); } From 8779b5edde6d689ccda335b8f0a2d638e7efa3c1 Mon Sep 17 00:00:00 2001 From: Benjamin Valentin Date: Tue, 24 Oct 2023 16:47:47 +0200 Subject: [PATCH 2/2] nib/_nib-6ln: don't check twice if address is assigned --- .../gnrc/network_layer/ipv6/nib/_nib-6ln.c | 22 +++++++------------ 1 file changed, 8 insertions(+), 14 deletions(-) diff --git a/sys/net/gnrc/network_layer/ipv6/nib/_nib-6ln.c b/sys/net/gnrc/network_layer/ipv6/nib/_nib-6ln.c index 816dae35b0b1..8219f701c151 100644 --- a/sys/net/gnrc/network_layer/ipv6/nib/_nib-6ln.c +++ b/sys/net/gnrc/network_layer/ipv6/nib/_nib-6ln.c @@ -196,7 +196,6 @@ void _handle_rereg_address(const ipv6_addr_t *addr) _nib_dr_entry_t *router = _nib_drl_get(NULL, netif->pid); const bool router_reachable = (router != NULL) && _is_reachable(router->next_hop); - if (router_reachable) { assert((unsigned)netif->pid == _nib_onl_get_if(router->next_hop)); DEBUG("nib: Re-registering %s", @@ -209,18 +208,16 @@ void _handle_rereg_address(const ipv6_addr_t *addr) else { DEBUG("nib: Couldn't re-register %s, no current router found.\n", ipv6_addr_to_str(addr_str, addr, sizeof(addr_str))); + netif->ipv6.rs_sent = 0; + _handle_search_rtr(netif); + goto out; } int idx = gnrc_netif_ipv6_addr_idx(netif, addr); - if (idx < 0) { - DEBUG("nib: %s is not assigned to interface %d anymore.\n", - ipv6_addr_to_str(addr_str, addr, sizeof(addr_str)), - netif->pid); - } - else if (router_reachable && - (_is_valid(netif, idx) || (_is_tentative(netif, idx) && - (gnrc_netif_ipv6_addr_dad_trans(netif, idx) < - SIXLOWPAN_ND_REG_TRANSMIT_NUMOF)))) { + assert(idx >= 0); + + if (_is_valid(netif, idx) || (_is_tentative(netif, idx) && + (gnrc_netif_ipv6_addr_dad_trans(netif, idx) < SIXLOWPAN_ND_REG_TRANSMIT_NUMOF))) { uint32_t retrans_time; if (_is_valid(netif, idx)) { @@ -234,10 +231,7 @@ void _handle_rereg_address(const ipv6_addr_t *addr) _evtimer_add(&netif->ipv6.addrs[idx], GNRC_IPV6_NIB_REREG_ADDRESS, &netif->ipv6.addrs_timers[idx], retrans_time); } - else { - netif->ipv6.rs_sent = 0; - _handle_search_rtr(netif); - } +out: gnrc_netif_release(netif); }