1998-10-18 20:50:43 +08:00
|
|
|
/*
|
1999-03-04 03:49:56 +08:00
|
|
|
* BIRD -- UNIX Kernel Route Syncer
|
1998-10-18 20:50:43 +08:00
|
|
|
*
|
2000-03-13 05:54:39 +08:00
|
|
|
* (c) 1998--2000 Martin Mares <mj@ucw.cz>
|
1998-10-18 20:50:43 +08:00
|
|
|
*
|
|
|
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _BIRD_KRT_H_
|
|
|
|
#define _BIRD_KRT_H_
|
|
|
|
|
1999-08-04 03:33:22 +08:00
|
|
|
struct config;
|
1999-03-04 03:49:56 +08:00
|
|
|
struct krt_config;
|
|
|
|
struct krt_proto;
|
1999-03-27 05:44:38 +08:00
|
|
|
struct kif_config;
|
|
|
|
struct kif_proto;
|
1999-03-04 03:49:56 +08:00
|
|
|
|
2012-05-01 04:21:52 +08:00
|
|
|
#include "lib/krt-sys.h"
|
1998-10-18 20:50:43 +08:00
|
|
|
|
2011-10-07 04:48:49 +08:00
|
|
|
/* Flags stored in net->n.flags, rest are in nest/route.h */
|
1998-12-07 18:15:42 +08:00
|
|
|
|
1999-04-03 21:05:18 +08:00
|
|
|
#define KRF_VERDICT_MASK 0x0f
|
1998-12-09 00:20:13 +08:00
|
|
|
#define KRF_CREATE 0 /* Not seen in kernel table */
|
1998-12-07 18:15:42 +08:00
|
|
|
#define KRF_SEEN 1 /* Seen in kernel table during last scan */
|
|
|
|
#define KRF_UPDATE 2 /* Need to update this entry */
|
1998-12-09 00:20:13 +08:00
|
|
|
#define KRF_DELETE 3 /* Should be deleted */
|
1999-04-03 21:05:18 +08:00
|
|
|
#define KRF_IGNORE 4 /* To be ignored */
|
|
|
|
|
2012-03-23 07:26:26 +08:00
|
|
|
#define EA_KRT_SOURCE EA_CODE(EAP_KRT, 0)
|
2012-03-23 08:17:02 +08:00
|
|
|
#define EA_KRT_METRIC EA_CODE(EAP_KRT, 1)
|
2011-04-13 18:32:27 +08:00
|
|
|
|
1999-04-03 21:05:18 +08:00
|
|
|
/* Whenever we recognize our own routes, we allow learing of foreign routes */
|
|
|
|
|
|
|
|
#ifdef CONFIG_SELF_CONSCIOUS
|
|
|
|
#define KRT_ALLOW_LEARN
|
|
|
|
#endif
|
1998-12-07 18:15:42 +08:00
|
|
|
|
1999-03-04 03:49:56 +08:00
|
|
|
/* krt.c */
|
1998-10-18 20:50:43 +08:00
|
|
|
|
|
|
|
extern struct protocol proto_unix_kernel;
|
|
|
|
|
1999-02-06 05:38:50 +08:00
|
|
|
struct krt_config {
|
|
|
|
struct proto_config c;
|
2012-04-30 21:31:32 +08:00
|
|
|
struct krt_params sys; /* Sysdep params */
|
1999-03-04 03:49:56 +08:00
|
|
|
int persist; /* Keep routes when we exit */
|
1999-03-27 05:44:38 +08:00
|
|
|
int scan_time; /* How often we re-scan routes */
|
1999-03-04 03:49:56 +08:00
|
|
|
int learn; /* Learn routes from other sources */
|
2010-04-04 21:41:31 +08:00
|
|
|
int devroutes; /* Allow export of device routes */
|
2014-03-20 21:07:12 +08:00
|
|
|
int graceful_restart; /* Regard graceful restart recovery */
|
1998-10-18 20:50:43 +08:00
|
|
|
};
|
|
|
|
|
1999-02-06 05:38:50 +08:00
|
|
|
struct krt_proto {
|
|
|
|
struct proto p;
|
2013-06-30 04:55:41 +08:00
|
|
|
struct krt_state sys; /* Sysdep state */
|
|
|
|
|
1999-04-03 21:05:18 +08:00
|
|
|
#ifdef KRT_ALLOW_LEARN
|
|
|
|
struct rtable krt_table; /* Internal table of inherited routes */
|
1999-08-04 03:33:22 +08:00
|
|
|
#endif
|
2013-06-30 04:55:41 +08:00
|
|
|
|
|
|
|
#ifndef CONFIG_ALL_TABLES_AT_ONCE
|
1999-08-04 03:33:22 +08:00
|
|
|
timer *scan_timer;
|
1999-04-03 21:05:18 +08:00
|
|
|
#endif
|
2013-06-30 04:55:41 +08:00
|
|
|
|
|
|
|
node krt_node; /* Node in krt_proto_list */
|
2014-03-20 21:07:12 +08:00
|
|
|
byte ready; /* Initial feed has been finished */
|
|
|
|
byte initialized; /* First scan has been finished */
|
2015-04-26 03:41:43 +08:00
|
|
|
byte reload; /* Next scan is doing reload */
|
1999-02-06 05:38:50 +08:00
|
|
|
};
|
|
|
|
|
1999-08-04 03:33:22 +08:00
|
|
|
extern pool *krt_pool;
|
1998-12-07 01:40:42 +08:00
|
|
|
|
1999-03-04 03:49:56 +08:00
|
|
|
#define KRT_CF ((struct krt_config *)p->p.cf)
|
|
|
|
|
2000-03-13 05:54:39 +08:00
|
|
|
#define KRT_TRACE(pr, fl, msg, args...) do { \
|
|
|
|
DBG("KRT: " msg "\n" , ## args); \
|
|
|
|
if (pr->p.debug & fl) \
|
|
|
|
{ log(L_TRACE "%s: " msg, pr->p.name , ## args); } } while(0)
|
|
|
|
|
2012-04-30 21:31:32 +08:00
|
|
|
struct proto_config * kif_init_config(int class);
|
2012-01-23 10:15:12 +08:00
|
|
|
void kif_request_scan(void);
|
1999-03-04 03:49:56 +08:00
|
|
|
void krt_got_route(struct krt_proto *p, struct rte *e);
|
1999-03-05 02:36:18 +08:00
|
|
|
void krt_got_route_async(struct krt_proto *p, struct rte *e, int new);
|
|
|
|
|
|
|
|
/* Values for rte->u.krt_sync.src */
|
|
|
|
#define KRT_SRC_UNKNOWN -1 /* Nobody knows */
|
|
|
|
#define KRT_SRC_BIRD 0 /* Our route (not passed in async mode) */
|
|
|
|
#define KRT_SRC_REDIRECT 1 /* Redirect route, delete it */
|
|
|
|
#define KRT_SRC_ALIEN 2 /* Route installed by someone else */
|
2010-02-26 17:55:58 +08:00
|
|
|
#define KRT_SRC_KERNEL 3 /* Kernel routes, are ignored by krt syncer */
|
1999-03-04 03:49:56 +08:00
|
|
|
|
1999-03-27 05:44:38 +08:00
|
|
|
extern struct protocol proto_unix_iface;
|
|
|
|
|
2009-05-29 19:32:24 +08:00
|
|
|
struct kif_primary_item {
|
|
|
|
node n;
|
|
|
|
byte *pattern;
|
|
|
|
ip_addr prefix;
|
|
|
|
int pxlen;
|
|
|
|
};
|
|
|
|
|
1999-03-27 05:44:38 +08:00
|
|
|
struct kif_config {
|
|
|
|
struct proto_config c;
|
2012-04-30 21:31:32 +08:00
|
|
|
struct kif_params sys; /* Sysdep params */
|
1999-03-27 05:44:38 +08:00
|
|
|
int scan_time; /* How often we re-scan interfaces */
|
2011-11-07 07:31:23 +08:00
|
|
|
list primary; /* Preferences for primary addresses (struct kif_primary_item) */
|
1999-03-27 05:44:38 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct kif_proto {
|
|
|
|
struct proto p;
|
2013-06-30 04:55:41 +08:00
|
|
|
struct kif_state sys; /* Sysdep state */
|
1999-03-27 05:44:38 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#define KIF_CF ((struct kif_config *)p->p.cf)
|
|
|
|
|
2012-04-30 21:31:32 +08:00
|
|
|
struct proto_config * krt_init_config(int class);
|
|
|
|
|
1998-10-18 20:50:43 +08:00
|
|
|
|
2012-05-01 04:21:52 +08:00
|
|
|
/* krt sysdep */
|
1999-03-04 03:49:56 +08:00
|
|
|
|
2012-04-30 21:31:32 +08:00
|
|
|
void krt_sys_init(struct krt_proto *);
|
2013-06-30 04:55:41 +08:00
|
|
|
void krt_sys_start(struct krt_proto *);
|
|
|
|
void krt_sys_shutdown(struct krt_proto *);
|
2012-04-30 21:31:32 +08:00
|
|
|
int krt_sys_reconfigure(struct krt_proto *p UNUSED, struct krt_config *n, struct krt_config *o);
|
1998-10-18 20:50:43 +08:00
|
|
|
|
2012-04-30 21:31:32 +08:00
|
|
|
void krt_sys_preconfig(struct config *);
|
|
|
|
void krt_sys_postconfig(struct krt_config *);
|
|
|
|
void krt_sys_init_config(struct krt_config *);
|
|
|
|
void krt_sys_copy_config(struct krt_config *, struct krt_config *);
|
1998-10-18 20:50:43 +08:00
|
|
|
|
2012-04-30 21:31:32 +08:00
|
|
|
int krt_capable(rte *e);
|
|
|
|
void krt_do_scan(struct krt_proto *);
|
2012-05-01 04:34:06 +08:00
|
|
|
void krt_replace_rte(struct krt_proto *p, net *n, rte *new, rte *old, struct ea_list *eattrs);
|
KRT: Add support for plenty of kernel route metrics
Linux kernel route metrics (RTA_METRICS netlink route attribute) are
represented and accessible as new route attributes:
krt_mtu, krt_window, krt_rtt, krt_rttvar, krt_sstresh, krt_cwnd, krt_advmss,
krt_reordering, krt_hoplimit, krt_initcwnd, krt_rto_min, krt_initrwnd,
krt_quickack, krt_lock_mtu, krt_lock_window, krt_lock_rtt, krt_lock_rttvar,
krt_lock_sstresh, krt_lock_cwnd, krt_lock_advmss, krt_lock_reordering,
krt_lock_hoplimit, krt_lock_rto_min, krt_feature_ecn, krt_feature_allfrag
2015-05-12 22:42:22 +08:00
|
|
|
int krt_sys_get_attr(eattr *a, byte *buf, int buflen);
|
1998-10-18 20:50:43 +08:00
|
|
|
|
1999-03-02 03:05:58 +08:00
|
|
|
|
2012-05-01 04:21:52 +08:00
|
|
|
/* kif sysdep */
|
1999-03-02 03:05:58 +08:00
|
|
|
|
2012-04-30 21:31:32 +08:00
|
|
|
void kif_sys_init(struct kif_proto *);
|
|
|
|
void kif_sys_start(struct kif_proto *);
|
|
|
|
void kif_sys_shutdown(struct kif_proto *);
|
|
|
|
int kif_sys_reconfigure(struct kif_proto *, struct kif_config *, struct kif_config *);
|
|
|
|
|
|
|
|
void kif_sys_init_config(struct kif_config *);
|
|
|
|
void kif_sys_copy_config(struct kif_config *, struct kif_config *);
|
|
|
|
|
|
|
|
void kif_do_scan(struct kif_proto *);
|
1998-12-09 02:37:58 +08:00
|
|
|
|
2013-11-25 08:21:39 +08:00
|
|
|
struct ifa *kif_get_primary_ip(struct iface *i);
|
1999-03-04 03:49:56 +08:00
|
|
|
|
1998-10-18 20:50:43 +08:00
|
|
|
#endif
|