0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-20 16:01:53 +00:00

BGP: Save sent and received OPEN messages

These are necessary for BMP Peer UP message and it is better to keep them
in BGP than in BMP (so BMP could be restarted or added later).
This commit is contained in:
Ondrej Zajicek 2023-04-28 19:13:56 +02:00
parent a8a64ca0fe
commit 1be0be1b71
3 changed files with 29 additions and 1 deletions

View File

@ -380,6 +380,13 @@ bgp_close_conn(struct bgp_conn *conn)
rfree(conn->sk); rfree(conn->sk);
conn->sk = NULL; conn->sk = NULL;
mb_free(conn->local_open_msg);
conn->local_open_msg = NULL;
mb_free(conn->remote_open_msg);
conn->remote_open_msg = NULL;
conn->local_open_length = 0;
conn->remote_open_length = 0;
mb_free(conn->local_caps); mb_free(conn->local_caps);
conn->local_caps = NULL; conn->local_caps = NULL;
mb_free(conn->remote_caps); mb_free(conn->remote_caps);

View File

@ -287,6 +287,11 @@ struct bgp_conn {
u8 ext_messages; /* Session uses extended message length */ u8 ext_messages; /* Session uses extended message length */
u32 received_as; /* ASN received in OPEN message */ u32 received_as; /* ASN received in OPEN message */
byte *local_open_msg; /* Saved OPEN messages (no header) */
byte *remote_open_msg;
uint local_open_length;
uint remote_open_length;
struct bgp_caps *local_caps; struct bgp_caps *local_caps;
struct bgp_caps *remote_caps; struct bgp_caps *remote_caps;
timer *connect_timer; timer *connect_timer;
@ -487,6 +492,7 @@ struct bgp_parse_state {
#define BGP_PORT 179 #define BGP_PORT 179
#define BGP_VERSION 4 #define BGP_VERSION 4
#define BGP_HEADER_LENGTH 19 #define BGP_HEADER_LENGTH 19
#define BGP_HDR_MARKER_LENGTH 16
#define BGP_MAX_MESSAGE_LENGTH 4096 #define BGP_MAX_MESSAGE_LENGTH 4096
#define BGP_MAX_EXT_MSG_LENGTH 65535 #define BGP_MAX_EXT_MSG_LENGTH 65535
#define BGP_RX_BUFFER_SIZE 4096 #define BGP_RX_BUFFER_SIZE 4096

View File

@ -772,6 +772,14 @@ err:
return -1; return -1;
} }
static byte *
bgp_copy_open(struct bgp_proto *p, const byte *pkt, uint len)
{
char *buf = mb_alloc(p->p.pool, len - BGP_HEADER_LENGTH);
memcpy(buf, pkt + BGP_HEADER_LENGTH, len - BGP_HEADER_LENGTH);
return buf;
}
static byte * static byte *
bgp_create_open(struct bgp_conn *conn, byte *buf) bgp_create_open(struct bgp_conn *conn, byte *buf)
{ {
@ -846,6 +854,9 @@ bgp_rx_open(struct bgp_conn *conn, byte *pkt, uint len)
id = get_u32(pkt+24); id = get_u32(pkt+24);
BGP_TRACE(D_PACKETS, "Got OPEN(as=%d,hold=%d,id=%R)", asn, hold, id); BGP_TRACE(D_PACKETS, "Got OPEN(as=%d,hold=%d,id=%R)", asn, hold, id);
conn->remote_open_msg = bgp_copy_open(p, pkt, len);
conn->remote_open_length = len - BGP_HEADER_LENGTH;
if (bgp_read_options(conn, pkt+29, pkt[28], len-29) < 0) if (bgp_read_options(conn, pkt+29, pkt[28], len-29) < 0)
return; return;
@ -2984,7 +2995,7 @@ bgp_send(struct bgp_conn *conn, uint type, uint len)
conn->bgp->stats.tx_messages++; conn->bgp->stats.tx_messages++;
conn->bgp->stats.tx_bytes += len; conn->bgp->stats.tx_bytes += len;
memset(buf, 0xff, 16); /* Marker */ memset(buf, 0xff, BGP_HDR_MARKER_LENGTH);
put_u16(buf+16, len); put_u16(buf+16, len);
buf[18] = type; buf[18] = type;
@ -3032,6 +3043,10 @@ bgp_fire_tx(struct bgp_conn *conn)
{ {
conn->packets_to_send &= ~(1 << PKT_OPEN); conn->packets_to_send &= ~(1 << PKT_OPEN);
end = bgp_create_open(conn, pkt); end = bgp_create_open(conn, pkt);
conn->local_open_msg = bgp_copy_open(p, buf, end - buf);
conn->local_open_length = end - buf - BGP_HEADER_LENGTH;
int rv = bgp_send(conn, PKT_OPEN, end - buf); int rv = bgp_send(conn, PKT_OPEN, end - buf);
if (rv >= 0) if (rv >= 0)
{ {