diff --git a/sys/net/gnrc/network_layer/ipv6/nib/_nib-internal.c b/sys/net/gnrc/network_layer/ipv6/nib/_nib-internal.c index 0a316bb5adef61588bfd2fcda4b2c34238ee9c8e..f366d5ec7c5acbc48c7ad8a0fa3cefcbd7c537cd 100644 --- a/sys/net/gnrc/network_layer/ipv6/nib/_nib-internal.c +++ b/sys/net/gnrc/network_layer/ipv6/nib/_nib-internal.c @@ -123,19 +123,18 @@ static inline _nib_onl_entry_t *_cache_out_onl_entry(const ipv6_addr_t *addr, res = tmp; res->mode = _EMPTY; _override_node(addr, iface, res); - /* cstate masked above already */ - res->info = cstate; + /* cstate masked in _nib_nc_add() already */ + res->info |= cstate; res->mode = _NC; - break; } - /* requeue if not garbage collectible at the moment */ - DEBUG("nib: Requeing (addr = %s, iface = %u)\n", - ipv6_addr_to_str(addr_str, &tmp->ipv6, - sizeof(addr_str)), - _nib_onl_get_if(tmp)); + /* requeue if not garbage collectible at the moment or queueing + * newly created NCE */ clist_rpush(&_next_removable, (clist_node_t *)tmp); - tmp = (_nib_onl_entry_t *)clist_lpop(&_next_removable); - } while (tmp != first); + if (res == NULL) { + /* no new entry created yet, get next entry in FIFO */ + tmp = (_nib_onl_entry_t *)clist_lpop(&_next_removable); + } + } while ((tmp != first) && (res != NULL)); return res; }