summaryrefslogtreecommitdiff
path: root/sbin/slaacd/engine.c
diff options
context:
space:
mode:
authorFlorian Obser <florian@cvs.openbsd.org>2017-08-04 14:17:48 +0000
committerFlorian Obser <florian@cvs.openbsd.org>2017-08-04 14:17:48 +0000
commit2965ed0135e80428a7d5230b130b32c69d880893 (patch)
tree5e0aae61d3dee6b1c51dd35b4a1bd5ab29949623 /sbin/slaacd/engine.c
parent3a9c60fdcb6d6401d3b8afc88f849569d49048b7 (diff)
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.
Diffstat (limited to 'sbin/slaacd/engine.c')
-rw-r--r--sbin/slaacd/engine.c51
1 files changed, 25 insertions, 26 deletions
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 <florian@openbsd.org>
@@ -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