From c42a3485bacc5f96c5f4dfe94bba50f91410fe06 Mon Sep 17 00:00:00 2001 From: Claudio Jeker Date: Wed, 30 Sep 2009 12:02:19 +0000 Subject: carp_demote_ioctl() can handle more then +/-1 steps so there is no need to loop in the shutdown case. OK henning@ --- usr.sbin/ospf6d/carp.c | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) (limited to 'usr.sbin/ospf6d/carp.c') diff --git a/usr.sbin/ospf6d/carp.c b/usr.sbin/ospf6d/carp.c index d34c277deab..d60ca911a58 100644 --- a/usr.sbin/ospf6d/carp.c +++ b/usr.sbin/ospf6d/carp.c @@ -1,4 +1,4 @@ -/* $OpenBSD: carp.c,v 1.1 2007/10/08 10:44:50 norby Exp $ */ +/* $OpenBSD: carp.c,v 1.2 2009/09/30 12:02:18 claudio Exp $ */ /* * Copyright (c) 2006 Henning Brauer @@ -90,9 +90,8 @@ carp_demote_shutdown(void) while ((c = TAILQ_FIRST(&carpgroups)) != NULL) { TAILQ_REMOVE(&carpgroups, c, entry); - for (; c->changed_by > 0; c->changed_by--) - if (c->do_demote) - carp_demote_ioctl(c->group, -1); + if (c->do_demote && c->changed_by > 0) + carp_demote_ioctl(c->group, -c->changed_by); free(c->group); free(c); -- cgit v1.2.3