summaryrefslogtreecommitdiff
path: root/usr.sbin/bgpd
diff options
context:
space:
mode:
authorClaudio Jeker <claudio@cvs.openbsd.org>2006-03-22 10:18:50 +0000
committerClaudio Jeker <claudio@cvs.openbsd.org>2006-03-22 10:18:50 +0000
commita0c23b70e67fe2df6df71f4a92cc2af672777c76 (patch)
tree0abf4274bfffc21e1812eb772eb882167e84fde4 /usr.sbin/bgpd
parentf18d04c61f8638df81719a6648f8b862ceeb1b26 (diff)
Add a new SHOW imsg to send optional attributes to bgpctl. This can be used
to show communites in bgpctl output. Only send these messages if it they are requested to reduce the overhead for simple listings. Looks good henning@
Diffstat (limited to 'usr.sbin/bgpd')
-rw-r--r--usr.sbin/bgpd/bgpd.h7
-rw-r--r--usr.sbin/bgpd/rde.c55
-rw-r--r--usr.sbin/bgpd/rde.h4
-rw-r--r--usr.sbin/bgpd/session.c3
4 files changed, 54 insertions, 15 deletions
diff --git a/usr.sbin/bgpd/bgpd.h b/usr.sbin/bgpd/bgpd.h
index 9573e2d2d92..fee67e23cab 100644
--- a/usr.sbin/bgpd/bgpd.h
+++ b/usr.sbin/bgpd/bgpd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: bgpd.h,v 1.193 2006/03/15 11:33:42 claudio Exp $ */
+/* $OpenBSD: bgpd.h,v 1.194 2006/03/22 10:18:49 claudio Exp $ */
/*
* Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org>
@@ -76,6 +76,7 @@
#define F_REJECT 0x0080
#define F_BLACKHOLE 0x0100
#define F_LONGER 0x0200
+#define F_CTL_DETAIL 0x1000 /* only used by bgpctl */
enum {
PROC_MAIN,
@@ -317,6 +318,7 @@ enum imsg_type {
IMSG_CTL_SHOW_RIB,
IMSG_CTL_SHOW_RIB_AS,
IMSG_CTL_SHOW_RIB_PREFIX,
+ IMSG_CTL_SHOW_RIB_ATTR,
IMSG_CTL_SHOW_NETWORK,
IMSG_CTL_SHOW_NETWORK6,
IMSG_CTL_SHOW_RIB_MEM,
@@ -464,7 +466,10 @@ struct kroute6_label {
struct ctl_show_rib {
struct bgpd_addr nexthop;
struct bgpd_addr prefix;
+ struct bgpd_addr remote_addr;
+ char descr[PEER_DESCR_LEN];
time_t lastchange;
+ u_int32_t remote_id;
u_int32_t local_pref;
u_int32_t med;
u_int32_t prefix_cnt;
diff --git a/usr.sbin/bgpd/rde.c b/usr.sbin/bgpd/rde.c
index 49ec0f622a5..fc6f5090ace 100644
--- a/usr.sbin/bgpd/rde.c
+++ b/usr.sbin/bgpd/rde.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rde.c,v 1.201 2006/03/13 16:49:35 claudio Exp $ */
+/* $OpenBSD: rde.c,v 1.202 2006/03/22 10:18:49 claudio Exp $ */
/*
* Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org>
@@ -58,9 +58,9 @@ void rde_update_log(const char *,
const struct rde_peer *, const struct bgpd_addr *,
const struct bgpd_addr *, u_int8_t);
int rde_reflector(struct rde_peer *, struct rde_aspath *);
-void rde_dump_rib_as(struct prefix *, pid_t);
+void rde_dump_rib_as(struct prefix *, pid_t, int);
void rde_dump_upcall(struct pt_entry *, void *);
-void rde_dump_as(struct filter_as *, pid_t);
+void rde_dump_as(struct filter_as *, pid_t, int);
void rde_dump_prefix_upcall(struct pt_entry *, void *);
void rde_dump_prefix(struct ctl_show_rib_prefix *, pid_t);
void rde_softreconfig_out(struct pt_entry *, void *);
@@ -305,7 +305,8 @@ rde_dispatch_imsg_session(struct imsgbuf *ibuf)
memcpy(&pconf, imsg.data, sizeof(pconf));
peer = peer_add(imsg.hdr.peerid, &pconf);
if (peer == NULL) {
- log_warnx("peer_up: peer id %d already exists",
+ log_warnx("session add: "
+ "peer id %d already exists",
imsg.hdr.peerid);
break;
}
@@ -422,7 +423,7 @@ badnet:
break;
}
pid = imsg.hdr.pid;
- rde_dump_as(imsg.data, pid);
+ rde_dump_as(imsg.data, pid, 1);
imsg_compose(ibuf_se, IMSG_CTL_END, 0, pid, -1,
NULL, 0);
break;
@@ -1473,17 +1474,25 @@ rde_reflector(struct rde_peer *peer, struct rde_aspath *asp)
* control specific functions
*/
void
-rde_dump_rib_as(struct prefix *p, pid_t pid)
+rde_dump_rib_as(struct prefix *p, pid_t pid, int all)
{
struct ctl_show_rib rib;
struct buf *wbuf;
+ struct attr *a;
+ void *bp;
+ u_int8_t l;
+ bzero(&rib, sizeof(rib));
rib.lastchange = p->lastchange;
rib.local_pref = p->aspath->lpref;
rib.med = p->aspath->med;
rib.prefix_cnt = p->aspath->prefix_cnt;
rib.active_cnt = p->aspath->active_cnt;
rib.adjrib_cnt = p->aspath->adjrib_cnt;
+ strlcpy(rib.descr, p->aspath->peer->conf.descr, sizeof(rib.descr));
+ memcpy(&rib.remote_addr, &p->aspath->peer->remote_addr,
+ sizeof(rib.remote_addr));
+ rib.remote_id = p->aspath->peer->remote_bgpid;
if (p->aspath->nexthop != NULL)
memcpy(&rib.nexthop, &p->aspath->nexthop->true_nexthop,
sizeof(rib.nexthop));
@@ -1516,6 +1525,26 @@ rde_dump_rib_as(struct prefix *p, pid_t pid)
return;
if (imsg_close(ibuf_se, wbuf) == -1)
return;
+
+ if (all)
+ for (l = 0; l < p->aspath->others_len; l++) {
+ if ((a = p->aspath->others[l]) == NULL)
+ break;
+ if ((wbuf = imsg_create(ibuf_se, IMSG_CTL_SHOW_RIB_ATTR,
+ 0, pid, attr_optlen(a))) == NULL)
+ return;
+ if ((bp = buf_reserve(wbuf, attr_optlen(a))) == NULL) {
+ buf_free(wbuf);
+ return;
+ }
+ if (attr_write(bp, attr_optlen(a), a->flags,
+ a->type, a->data, a->len) == -1) {
+ buf_free(wbuf);
+ return;
+ }
+ if (imsg_close(ibuf_se, wbuf) == -1)
+ return;
+ }
}
void
@@ -1529,11 +1558,11 @@ rde_dump_upcall(struct pt_entry *pt, void *ptr)
LIST_FOREACH(p, &pt->prefix_h, prefix_l)
/* for now dump only stuff from the local-RIB */
if (p->flags & F_LOCAL)
- rde_dump_rib_as(p, pid);
+ rde_dump_rib_as(p, pid, 0);
}
void
-rde_dump_as(struct filter_as *a, pid_t pid)
+rde_dump_as(struct filter_as *a, pid_t pid, int flags)
{
extern struct path_table pathtable;
struct rde_aspath *asp;
@@ -1548,7 +1577,7 @@ rde_dump_as(struct filter_as *a, pid_t pid)
LIST_FOREACH(p, &asp->prefix_h, path_l)
/* for now dump only stuff from the local-RIB */
if (p->flags & F_LOCAL)
- rde_dump_rib_as(p, pid);
+ rde_dump_rib_as(p, pid, flags);
}
}
}
@@ -1572,7 +1601,7 @@ rde_dump_prefix_upcall(struct pt_entry *pt, void *ptr)
LIST_FOREACH(p, &pt->prefix_h, prefix_l)
/* for now dump only stuff from the local-RIB */
if (p->flags & F_LOCAL)
- rde_dump_rib_as(p, ctl->pid);
+ rde_dump_rib_as(p, ctl->pid, 0);
}
void
@@ -2247,20 +2276,22 @@ void
network_init(struct network_head *net_l)
{
struct network *n;
+ struct in_addr id;
reloadtime = time(NULL);
bzero(&peerself, sizeof(peerself));
peerself.state = PEER_UP;
peerself.remote_bgpid = conf->bgpid;
+ id.s_addr = conf->bgpid;
peerself.conf.remote_as = conf->as;
snprintf(peerself.conf.descr, sizeof(peerself.conf.descr),
- "LOCAL AS %hu", conf->as);
+ "LOCAL: ID %s", inet_ntoa(id));
bzero(&peerdynamic, sizeof(peerdynamic));
peerdynamic.state = PEER_UP;
peerdynamic.remote_bgpid = conf->bgpid;
peerdynamic.conf.remote_as = conf->as;
snprintf(peerdynamic.conf.descr, sizeof(peerdynamic.conf.descr),
- "LOCAL AS %hu", conf->as);
+ "LOCAL: ID %s", inet_ntoa(id));
while ((n = TAILQ_FIRST(net_l)) != NULL) {
TAILQ_REMOVE(net_l, n, entry);
diff --git a/usr.sbin/bgpd/rde.h b/usr.sbin/bgpd/rde.h
index 87471be8474..acfc973e6f4 100644
--- a/usr.sbin/bgpd/rde.h
+++ b/usr.sbin/bgpd/rde.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: rde.h,v 1.89 2006/02/09 21:05:09 claudio Exp $ */
+/* $OpenBSD: rde.h,v 1.90 2006/03/22 10:18:49 claudio Exp $ */
/*
* Copyright (c) 2003, 2004 Claudio Jeker <claudio@openbsd.org> and
@@ -272,6 +272,8 @@ struct attr *attr_optget(const struct rde_aspath *, u_int8_t);
void attr_copy(struct rde_aspath *, struct rde_aspath *);
int attr_compare(struct rde_aspath *, struct rde_aspath *);
void attr_freeall(struct rde_aspath *);
+#define attr_optlen(x) \
+ ((x)->len > 255 ? (x)->len + 4 : (x)->len + 3)
int aspath_verify(void *, u_int16_t);
#define AS_ERR_LEN -1
diff --git a/usr.sbin/bgpd/session.c b/usr.sbin/bgpd/session.c
index faf343ae23b..1f46322b205 100644
--- a/usr.sbin/bgpd/session.c
+++ b/usr.sbin/bgpd/session.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: session.c,v 1.245 2006/03/15 11:33:42 claudio Exp $ */
+/* $OpenBSD: session.c,v 1.246 2006/03/22 10:18:49 claudio Exp $ */
/*
* Copyright (c) 2003, 2004, 2005 Henning Brauer <henning@openbsd.org>
@@ -2318,6 +2318,7 @@ session_dispatch_imsg(struct imsgbuf *ibuf, int idx, u_int *listener_cnt)
break;
case IMSG_CTL_SHOW_RIB:
case IMSG_CTL_SHOW_RIB_PREFIX:
+ case IMSG_CTL_SHOW_RIB_ATTR:
case IMSG_CTL_SHOW_RIB_MEM:
case IMSG_CTL_SHOW_NETWORK:
case IMSG_CTL_SHOW_NETWORK6: