From 2965ed0135e80428a7d5230b130b32c69d880893 Mon Sep 17 00:00:00 2001 From: Florian Obser Date: Fri, 4 Aug 2017 14:17:48 +0000 Subject: No need for LIST_FOREACH_SAFE, we want to remove exactly one interface and then stop the iteration. get_slaacd_iface_by_id() is perfectly fine for this; we also gain one level of indentation. While here LIST_REMOVE the currently deleted dfr_proposal. --- sbin/slaacd/engine.c | 51 +++++++++++++++++++++++++-------------------------- 1 file changed, 25 insertions(+), 26 deletions(-) (limited to 'sbin/slaacd/engine.c') diff --git a/sbin/slaacd/engine.c b/sbin/slaacd/engine.c index b9cb943e63f..9e3b07888d4 100644 --- a/sbin/slaacd/engine.c +++ b/sbin/slaacd/engine.c @@ -1,4 +1,4 @@ -/* $OpenBSD: engine.c,v 1.9 2017/08/04 14:00:33 florian Exp $ */ +/* $OpenBSD: engine.c,v 1.10 2017/08/04 14:17:47 florian Exp $ */ /* * Copyright (c) 2017 Florian Obser @@ -856,36 +856,35 @@ get_slaacd_iface_by_id(uint32_t if_index) void remove_slaacd_iface(uint32_t if_index) { - struct slaacd_iface *iface, *tiface; + struct slaacd_iface *iface; struct radv *ra; struct address_proposal *addr_proposal; struct dfr_proposal *dfr_proposal; - LIST_FOREACH_SAFE (iface, &slaacd_interfaces, entries, tiface) { - if (iface->if_index == if_index) { - LIST_REMOVE(iface, entries); - while(!LIST_EMPTY(&iface->radvs)) { - ra = LIST_FIRST(&iface->radvs); - LIST_REMOVE(ra, entries); - free_ra(ra); - } - /* XXX inform netcfgd? */ - while(!LIST_EMPTY(&iface->addr_proposals)) { - addr_proposal = - LIST_FIRST(&iface->addr_proposals); - LIST_REMOVE(addr_proposal, entries); - free_address_proposal(addr_proposal); - } - while(!LIST_EMPTY(&iface->dfr_proposals)) { - dfr_proposal = - LIST_FIRST(&iface->dfr_proposals); - free_dfr_proposal(dfr_proposal); - } - evtimer_del(&iface->timer); - free(iface); - break; - } + iface = get_slaacd_iface_by_id(if_index); + + if (iface == NULL) + return; + + LIST_REMOVE(iface, entries); + while(!LIST_EMPTY(&iface->radvs)) { + ra = LIST_FIRST(&iface->radvs); + LIST_REMOVE(ra, entries); + free_ra(ra); + } + /* XXX inform netcfgd? */ + while(!LIST_EMPTY(&iface->addr_proposals)) { + addr_proposal = LIST_FIRST(&iface->addr_proposals); + LIST_REMOVE(addr_proposal, entries); + free_address_proposal(addr_proposal); + } + while(!LIST_EMPTY(&iface->dfr_proposals)) { + dfr_proposal = LIST_FIRST(&iface->dfr_proposals); + LIST_REMOVE(dfr_proposal, entries); + free_dfr_proposal(dfr_proposal); } + evtimer_del(&iface->timer); + free(iface); } void -- cgit v1.2.3