summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/bgpd/log.h3
-rw-r--r--usr.sbin/bgpd/session.c22
-rw-r--r--usr.sbin/bgpd/session.h3
3 files changed, 14 insertions, 14 deletions
diff --git a/usr.sbin/bgpd/log.h b/usr.sbin/bgpd/log.h
index 884ff1584e2..deb480ab453 100644
--- a/usr.sbin/bgpd/log.h
+++ b/usr.sbin/bgpd/log.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: log.h,v 1.10 2007/12/23 18:26:13 henning Exp $ */
+/* $OpenBSD: log.h,v 1.11 2008/09/11 14:49:58 henning Exp $ */
/*
* Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org>
@@ -119,5 +119,6 @@ static const char * const timernames[] = {
"HoldTimer",
"IdleHoldTimer",
"IdleHoldResetTimer",
+ "CarpUndemoteTimer",
""
};
diff --git a/usr.sbin/bgpd/session.c b/usr.sbin/bgpd/session.c
index 8ae17ce80ef..b763e35814e 100644
--- a/usr.sbin/bgpd/session.c
+++ b/usr.sbin/bgpd/session.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: session.c,v 1.283 2008/09/05 10:38:12 henning Exp $ */
+/* $OpenBSD: session.c,v 1.284 2008/09/11 14:49:58 henning Exp $ */
/*
* Copyright (c) 2003, 2004, 2005 Henning Brauer <henning@openbsd.org>
@@ -438,6 +438,12 @@ session_main(struct bgpd_config *config, struct peer *cpeers,
Timer_IdleHoldReset,
p->IdleHoldTime);
break;
+ case Timer_CarpUndemote:
+ timer_stop(p, Timer_CarpUndemote);
+ if (p->demoted &&
+ p->state == STATE_ESTABLISHED)
+ session_demote(p, -1);
+ break;
default:
fatalx("King Bula lost in time");
}
@@ -446,17 +452,6 @@ session_main(struct bgpd_config *config, struct peer *cpeers,
nextaction < timeout)
timeout = nextaction;
- /* XXX carp demotion */
- if (p->demoted && p->state == STATE_ESTABLISHED) {
- if (time(NULL) - p->stats.last_updown >=
- INTERVAL_HOLD_DEMOTED)
- session_demote(p, -1);
- if (p->stats.last_updown + INTERVAL_HOLD_DEMOTED
- - time(NULL) < timeout)
- timeout = p->stats.last_updown +
- INTERVAL_HOLD_DEMOTED - time(NULL);
- }
-
/* are we waiting for a write? */
events = POLLIN;
if (p->wbuf.queued > 0 || p->state == STATE_CONNECT)
@@ -953,6 +948,9 @@ change_state(struct peer *peer, enum session_state state,
break;
case STATE_ESTABLISHED:
timer_set(peer, Timer_IdleHoldReset, peer->IdleHoldTime);
+ if (peer->demoted)
+ timer_set(peer, Timer_CarpUndemote,
+ INTERVAL_HOLD_DEMOTED);
session_up(peer);
break;
default: /* something seriously fucked */
diff --git a/usr.sbin/bgpd/session.h b/usr.sbin/bgpd/session.h
index 09dc542114f..b1f8553444b 100644
--- a/usr.sbin/bgpd/session.h
+++ b/usr.sbin/bgpd/session.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: session.h,v 1.98 2008/05/08 09:53:12 henning Exp $ */
+/* $OpenBSD: session.h,v 1.99 2008/09/11 14:49:58 henning Exp $ */
/*
* Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org>
@@ -171,6 +171,7 @@ enum Timer {
Timer_Hold,
Timer_IdleHold,
Timer_IdleHoldReset,
+ Timer_CarpUndemote,
Timer_Max
};