summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/bgpd/session.c26
-rw-r--r--usr.sbin/bgpd/session.h5
2 files changed, 28 insertions, 3 deletions
diff --git a/usr.sbin/bgpd/session.c b/usr.sbin/bgpd/session.c
index c78f59457a5..0f1d125caa7 100644
--- a/usr.sbin/bgpd/session.c
+++ b/usr.sbin/bgpd/session.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: session.c,v 1.139 2004/03/20 23:17:35 david Exp $ */
+/* $OpenBSD: session.c,v 1.140 2004/04/13 22:53:29 henning Exp $ */
/*
* Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org>
@@ -1624,7 +1624,9 @@ parse_capabilities(struct peer *peer, u_char *d, u_int16_t dlen)
u_int16_t len;
u_int8_t capa_code;
u_int8_t capa_len;
- void *capa_val;
+ u_char *capa_val;
+ u_int16_t mp_afi;
+ u_int8_t mp_safi;
len = dlen;
while (len > 0) {
@@ -1646,6 +1648,26 @@ parse_capabilities(struct peer *peer, u_char *d, u_int16_t dlen)
capa_val = NULL;
switch (capa_code) {
+ case CAPA_MP: /* RFC 2858 */
+ if (capa_len != 4)
+ return (-1);
+ memcpy(&mp_afi, capa_val, sizeof(mp_afi));
+ memcpy(&mp_safi, capa_val + 3, sizeof(mp_safi));
+ switch (mp_afi) {
+ case AFI_IPv4:
+ if (mp_safi < 1 || mp_safi > 3)
+ return (-1);
+ peer->capa.mp_v4 = mp_safi;
+ break;
+ case AFI_IPv6:
+ if (mp_safi < 1 || mp_safi > 3)
+ return (-1);
+ peer->capa.mp_v6 = mp_safi;
+ break;
+ default: /* ignore */
+ break;
+ }
+ break;
default:
break;
}
diff --git a/usr.sbin/bgpd/session.h b/usr.sbin/bgpd/session.h
index 1a8becb38a4..943bcd1efa2 100644
--- a/usr.sbin/bgpd/session.h
+++ b/usr.sbin/bgpd/session.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: session.h,v 1.39 2004/03/11 14:22:23 claudio Exp $ */
+/* $OpenBSD: session.h,v 1.40 2004/04/13 22:53:29 henning Exp $ */
/*
* Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org>
@@ -142,6 +142,9 @@ struct peer_auth {
struct peer_capa {
u_int8_t announce;
+ u_int8_t mp_v4; /* multiprotocol extensions, RFC 2858 */
+ u_int8_t mp_v6;
+ u_int8_t refresh; /* route refresh, RFC 2918 */
};
struct peer {