diff options
-rw-r--r-- | usr.sbin/bgpd/bgpd.h | 3 | ||||
-rw-r--r-- | usr.sbin/bgpd/config.c | 5 | ||||
-rw-r--r-- | usr.sbin/bgpd/parse.y | 8 | ||||
-rw-r--r-- | usr.sbin/bgpd/rde_decide.c | 4 |
4 files changed, 11 insertions, 9 deletions
diff --git a/usr.sbin/bgpd/bgpd.h b/usr.sbin/bgpd/bgpd.h index c5a513dd513..e29e6ddc481 100644 --- a/usr.sbin/bgpd/bgpd.h +++ b/usr.sbin/bgpd/bgpd.h @@ -1,4 +1,4 @@ -/* $OpenBSD: bgpd.h,v 1.88 2004/01/28 23:31:28 henning Exp $ */ +/* $OpenBSD: bgpd.h,v 1.89 2004/02/01 19:46:05 claudio Exp $ */ /* * Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org> @@ -118,6 +118,7 @@ struct buf_read { }; enum announce_type { + ANNOUNCE_UNDEF, ANNOUNCE_SELF, ANNOUNCE_NONE, ANNOUNCE_ALL diff --git a/usr.sbin/bgpd/config.c b/usr.sbin/bgpd/config.c index 852bfa58013..672b1078794 100644 --- a/usr.sbin/bgpd/config.c +++ b/usr.sbin/bgpd/config.c @@ -1,4 +1,4 @@ -/* $OpenBSD: config.c,v 1.25 2004/01/30 23:24:04 henning Exp $ */ +/* $OpenBSD: config.c,v 1.26 2004/02/01 19:46:05 claudio Exp $ */ /* * Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org> @@ -56,6 +56,9 @@ merge_config(struct bgpd_config *xconf, struct bgpd_config *conf, for (p = peer_l; p != NULL; p = p->next) { p->conf.ebgp = (p->conf.remote_as != conf->as); + if (p->conf.announce_type == ANNOUNCE_UNDEF) + p->conf.announce_type = p->conf.ebgp == 0 ? + ANNOUNCE_ALL : ANNOUNCE_SELF; if (!p->conf.id) p->conf.id = get_id(p); } diff --git a/usr.sbin/bgpd/parse.y b/usr.sbin/bgpd/parse.y index c0665585770..71a3f3ae3b4 100644 --- a/usr.sbin/bgpd/parse.y +++ b/usr.sbin/bgpd/parse.y @@ -1,4 +1,4 @@ -/* $OpenBSD: parse.y,v 1.44 2004/01/28 23:49:55 henning Exp $ */ +/* $OpenBSD: parse.y,v 1.45 2004/02/01 19:46:05 claudio Exp $ */ /* * Copyright (c) 2002, 2003, 2004 Henning Brauer <henning@openbsd.org> @@ -810,7 +810,7 @@ alloc_peer(void) p->state = STATE_NONE; p->next = NULL; p->conf.distance = 1; - p->conf.announce_type = ANNOUNCE_SELF; + p->conf.announce_type = ANNOUNCE_UNDEF; p->conf.max_prefix = ULONG_MAX; return (p); @@ -832,11 +832,7 @@ new_peer(void) sizeof(p->conf.descr)) >= sizeof(p->conf.descr)) fatalx("new_peer descr strlcpy"); } - p->state = STATE_NONE; p->next = NULL; - p->conf.distance = 1; - p->conf.announce_type = ANNOUNCE_SELF; - p->conf.max_prefix = ULONG_MAX; return (p); } diff --git a/usr.sbin/bgpd/rde_decide.c b/usr.sbin/bgpd/rde_decide.c index a52ba3eedd0..15116572788 100644 --- a/usr.sbin/bgpd/rde_decide.c +++ b/usr.sbin/bgpd/rde_decide.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rde_decide.c,v 1.25 2004/01/27 16:49:53 henning Exp $ */ +/* $OpenBSD: rde_decide.c,v 1.26 2004/02/01 19:46:05 claudio Exp $ */ /* * Copyright (c) 2003, 2004 Claudio Jeker <claudio@openbsd.org> @@ -437,6 +437,7 @@ up_generate_updates(struct rde_peer *peer, /* announce type handling */ switch (peer->conf.announce_type) { + case ANNOUNCE_UNDEF: case ANNOUNCE_NONE: return; case ANNOUNCE_ALL: @@ -471,6 +472,7 @@ up_generate_updates(struct rde_peer *peer, /* announce type handling */ switch (peer->conf.announce_type) { + case ANNOUNCE_UNDEF: case ANNOUNCE_NONE: return; case ANNOUNCE_ALL: |