Add internal BMP functions with plicit bmp_proto *p as first argument, which allows using TRACE() macro. Keep list of BMP instances and call internal functions. Old BMP functions are wrappers that call internal functions for all enabled BMP instances. Extract End-of-RIB mark into separate function. Based on patch from Michal Zagorski <mzagorsk@akamai.com>. Thanks!
140 lines
5.5 KiB
C
140 lines
5.5 KiB
C
/*
|
|
* BIRD -- The BGP Monitoring Protocol (BMP)
|
|
*
|
|
* (c) 2020 Akamai Technologies, Inc. (Pawel Maslanka, pmaslank@akamai.com)
|
|
*
|
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
|
*/
|
|
|
|
#ifndef _BIRD_BMP_H_
|
|
#define _BIRD_BMP_H_
|
|
|
|
#include "nest/bird.h"
|
|
#include "nest/protocol.h"
|
|
#include "lib/lists.h"
|
|
#include "nest/route.h"
|
|
#include "lib/event.h"
|
|
#include "lib/hash.h"
|
|
#include "lib/socket.h"
|
|
#include "proto/bmp/map.h"
|
|
|
|
#include <stdbool.h>
|
|
|
|
// Max length of MIB-II description object
|
|
#define MIB_II_STR_LEN 255
|
|
|
|
// The following fields of this structure controls whether there will be put
|
|
// specific routes into Route Monitoring message and send to BMP collector
|
|
struct monitoring_rib {
|
|
bool in_pre_policy; // Monitoring pre-policy Adj-Rib-In
|
|
bool in_post_policy; // Monitoring post-policy Adj-Rib-In
|
|
bool local; // Monitoring Local Rib
|
|
};
|
|
|
|
struct bmp_config {
|
|
struct proto_config c;
|
|
const char *sys_descr; // sysDescr MIB-II [RFC1213] object
|
|
const char *sys_name; // sysName MIB-II [RFC1213] object
|
|
ip_addr local_addr; // Local IP address
|
|
ip_addr station_ip; // Monitoring station address
|
|
u16 station_port; // Monitoring station TCP port
|
|
bool monitoring_rib_in_pre_policy; // Route monitoring pre-policy Adj-Rib-In
|
|
};
|
|
|
|
/* Forward declarations */
|
|
struct bgp_proto;
|
|
struct bmp_proto;
|
|
|
|
// Keeps necessary information during composing BGP UPDATE MSG which is going
|
|
// to be sent to the BMP collector
|
|
struct rt_table_info {
|
|
list update_msg_queue; // Stores all composed BGP UPDATE MSGs
|
|
size_t update_msg_size; // Size of all BGP UPDATE MSGs
|
|
struct timeval update_begin_time; // Keeps timestamp of starting BGP UPDATE MSGs composing
|
|
bool update_in_progress; // Holds information whether composing process is still in progress
|
|
};
|
|
|
|
struct bmp_proto {
|
|
struct proto p; // Parent proto
|
|
const struct bmp_config *cf; // Shortcut to BMP configuration
|
|
node bmp_node; // Node in bmp_proto_list
|
|
sock *sk; // TCP connection
|
|
event *tx_ev; // TX event
|
|
char sys_descr[MIB_II_STR_LEN]; // sysDescr MIB-II [RFC1213] object
|
|
char sys_name[MIB_II_STR_LEN]; // sysName MIB-II [RFC1213] object
|
|
ip_addr local_addr; // Source local IP address
|
|
ip_addr station_ip; // Monitoring station IP address
|
|
u16 station_port; // Monitoring station TCP port
|
|
struct monitoring_rib monitoring_rib;
|
|
// Below fields are for internal use
|
|
// struct bmp_peer_map bgp_peers; // Stores 'bgp_proto' structure per BGP peer
|
|
pool *buffer_mpool; // Memory pool used for BMP buffer allocations
|
|
pool *map_mem_pool; // Memory pool used for BMP map allocations
|
|
pool *tx_mem_pool; // Memory pool used for packet allocations designated to BMP collector
|
|
pool *update_msg_mem_pool; // Memory pool used for BPG UPDATE MSG allocations
|
|
list tx_queue; // Stores queued packets going to be sent
|
|
timer *connect_retry_timer; // Timer for retrying connection to the BMP collector
|
|
struct rt_table_info rt_table_in_pre_policy; // Pre-policy route import table
|
|
bool started; // Flag that stores running status of BMP instance
|
|
int sock_err; // Last socket error code
|
|
};
|
|
|
|
|
|
#ifdef CONFIG_BMP
|
|
|
|
/**
|
|
* bmp_peer_up - send notification that BGP peer connection is established
|
|
*/
|
|
void
|
|
bmp_peer_up(const struct bgp_proto *bgp,
|
|
const byte *tx_open_msg, uint tx_open_length,
|
|
const byte *rx_open_msg, uint rx_open_length);
|
|
|
|
/**
|
|
* The following 5 functions create BMP Route Monitoring message based on
|
|
* pre-policy Adj-RIB-In. Composing Route Monitoring message consist of few
|
|
* stages. First of all call bmp_route_monitor_update_in_pre_begin() in order
|
|
* to start composing message. As a second step, call
|
|
* bmp_route_monitor_update_in_notify() to announce each rte, which internally
|
|
* calls bmp_route_monitor_put_update_in_pre_msg() in order to save BGP UPDATE
|
|
* msg. As a third step call bmp_route_monitor_update_in_pre_commit() in order
|
|
* to send BMP Route Monitoring message to the BMP collector. As a last step,
|
|
* call bmp_route_monitor_update_in_pre_end() in order to release resources.
|
|
*/
|
|
void
|
|
bmp_route_monitor_update_in_pre_begin(void);
|
|
|
|
void
|
|
bmp_route_monitor_update_in_notify(struct channel *C, const net_addr *n,
|
|
const struct rte *new, const struct rte_src *src);
|
|
|
|
void
|
|
bmp_route_monitor_update_in_pre_commit(const struct bgp_proto *bgp);
|
|
|
|
void
|
|
bmp_route_monitor_update_in_pre_end(void);
|
|
|
|
void
|
|
bmp_route_monitor_put_update_in_pre_msg(struct bmp_proto *p, const byte *data, const size_t data_size);
|
|
|
|
/**
|
|
* bmp_peer_down - send notification that BGP peer connection is not in
|
|
* established state
|
|
*/
|
|
void
|
|
bmp_peer_down(const struct bgp_proto *bgp, const int err_class, const byte *pkt,
|
|
size_t pkt_size);
|
|
|
|
|
|
#else /* BMP build disabled */
|
|
|
|
static inline void bmp_peer_up(const struct bgp_proto *bgp UNUSED, const byte *tx_open_msg UNUSED, uint tx_open_length UNUSED, const byte *rx_open_msg UNUSED, uint rx_open_length UNUSED) { }
|
|
static inline void bmp_route_monitor_update_in_pre_begin(void) { }
|
|
static inline void bmp_route_monitor_update_in_pre_commit(const struct bgp_proto *bgp UNUSED) { }
|
|
static inline void bmp_route_monitor_update_in_pre_end(void) { }
|
|
static inline void bmp_peer_down(const struct bgp_proto *bgp UNUSED, const int err_class UNUSED, const byte *pkt UNUSED, size_t pkt_size UNUSED) { }
|
|
|
|
#endif /* CONFIG_BMP */
|
|
|
|
#endif /* _BIRD_BMP_H_ */
|