| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	BIRD Internet Routing Daemon -- Protocols | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  |  *	(c) 1998--1999 Martin Mares <mj@ucw.cz> | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  *	Can be freely distributed and used under the terms of the GNU GPL. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _BIRD_PROTOCOL_H_
 | 
					
						
							|  |  |  | #define _BIRD_PROTOCOL_H_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-05-20 11:54:33 +00:00
										 |  |  | #include "lib/lists.h"
 | 
					
						
							| 
									
										
										
										
											1998-04-28 14:39:34 +00:00
										 |  |  | #include "lib/resource.h"
 | 
					
						
							| 
									
										
										
										
											1999-12-01 12:00:15 +00:00
										 |  |  | #include "lib/timer.h"
 | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-05-20 11:54:33 +00:00
										 |  |  | struct iface; | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | struct ifa; | 
					
						
							| 
									
										
										
										
											1998-05-20 11:54:33 +00:00
										 |  |  | struct rte; | 
					
						
							|  |  |  | struct neighbor; | 
					
						
							| 
									
										
										
										
											1999-03-01 20:13:54 +00:00
										 |  |  | struct rta; | 
					
						
							| 
									
										
										
										
											1998-08-31 21:13:42 +00:00
										 |  |  | struct network; | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  | struct proto_config; | 
					
						
							|  |  |  | struct config; | 
					
						
							|  |  |  | struct proto; | 
					
						
							| 
									
										
										
										
											1999-02-11 22:45:54 +00:00
										 |  |  | struct event; | 
					
						
							| 
									
										
										
										
											1999-05-31 18:55:35 +00:00
										 |  |  | struct ea_list; | 
					
						
							| 
									
										
										
										
											1999-11-25 15:35:30 +00:00
										 |  |  | struct symbol; | 
					
						
							| 
									
										
										
										
											1998-05-20 11:54:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	Routing Protocol | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct protocol { | 
					
						
							| 
									
										
										
										
											1998-06-03 08:38:06 +00:00
										 |  |  |   node n; | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  |   char *name; | 
					
						
							| 
									
										
										
										
											2000-01-17 11:52:50 +00:00
										 |  |  |   char *template;			/* Template for automatic generation of names */ | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  |   unsigned debug;			/* Default debugging flags */ | 
					
						
							| 
									
										
										
										
											1999-03-03 19:33:54 +00:00
										 |  |  |   int priority;				/* Protocol priority (usually 0) */ | 
					
						
							| 
									
										
										
										
											1999-03-26 21:37:29 +00:00
										 |  |  |   int name_counter;			/* Counter for automatic name generation */ | 
					
						
							| 
									
										
										
										
											1999-08-03 19:31:54 +00:00
										 |  |  |   int startup_counter;			/* Number of instances waiting for initialization */ | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  |   void (*preconfig)(struct protocol *, struct config *);	/* Just before configuring */ | 
					
						
							|  |  |  |   void (*postconfig)(struct proto_config *);			/* After configuring each instance */ | 
					
						
							|  |  |  |   struct proto * (*init)(struct proto_config *);		/* Create new instance */ | 
					
						
							| 
									
										
										
										
											2000-01-16 16:44:50 +00:00
										 |  |  |   int (*reconfigure)(struct proto *, struct proto_config *);	/* Try to reconfigure instance, returns success */ | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  |   void (*dump)(struct proto *);			/* Debugging dump */ | 
					
						
							| 
									
										
										
										
											1999-04-03 13:01:58 +00:00
										 |  |  |   void (*dump_attrs)(struct rte *);		/* Dump protocol-dependent attributes */ | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  |   int (*start)(struct proto *);			/* Start the instance */ | 
					
						
							|  |  |  |   int (*shutdown)(struct proto *);		/* Stop the instance */ | 
					
						
							| 
									
										
										
										
											1999-12-01 12:00:15 +00:00
										 |  |  |   void (*get_status)(struct proto *, byte *buf); /* Get instance status (for `show protocols' command) */ | 
					
						
							| 
									
										
										
										
											1999-12-01 15:08:32 +00:00
										 |  |  |   void (*get_route_info)(struct rte *, byte *buf); /* Get route information (for `show route' command) */ | 
					
						
							|  |  |  |   void (*show_route_data)(struct rte *);	/* Print verbose route information (`show route' again) */ | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-10-18 11:53:21 +00:00
										 |  |  | void protos_build(void); | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  | void protos_preconfig(struct config *); | 
					
						
							|  |  |  | void protos_postconfig(struct config *); | 
					
						
							| 
									
										
										
										
											2000-01-16 16:44:50 +00:00
										 |  |  | void protos_commit(struct config *new, struct config *old, int force_restart); | 
					
						
							| 
									
										
										
										
											1998-07-09 19:36:52 +00:00
										 |  |  | void protos_dump_all(void); | 
					
						
							| 
									
										
										
										
											1998-06-03 08:38:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | extern list protocol_list; | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *	Known protocols | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-06-03 08:38:06 +00:00
										 |  |  | extern struct protocol proto_device; | 
					
						
							| 
									
										
										
										
											1998-07-09 19:36:52 +00:00
										 |  |  | extern struct protocol proto_rip; | 
					
						
							| 
									
										
										
										
											1998-12-06 18:21:23 +00:00
										 |  |  | extern struct protocol proto_static; | 
					
						
							| 
									
										
										
										
											1999-03-09 22:27:43 +00:00
										 |  |  | extern struct protocol proto_ospf; | 
					
						
							| 
									
										
										
										
											1999-08-03 19:34:26 +00:00
										 |  |  | extern struct protocol proto_pipe; | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *	Routing Protocol Instance | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  | struct proto_config { | 
					
						
							|  |  |  |   node n; | 
					
						
							|  |  |  |   struct config *global;		/* Global configuration data */ | 
					
						
							| 
									
										
										
										
											1999-11-30 14:04:09 +00:00
										 |  |  |   struct protocol *protocol;		/* Protocol */ | 
					
						
							|  |  |  |   struct proto *proto;			/* Instance we've created */ | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  |   char *name; | 
					
						
							|  |  |  |   unsigned debug, preference, disabled;	/* Generic parameters */ | 
					
						
							| 
									
										
										
										
											1999-05-17 20:14:52 +00:00
										 |  |  |   struct rtable_config *table;		/* Table we're attached to */ | 
					
						
							| 
									
										
										
										
											1999-03-17 14:31:26 +00:00
										 |  |  |   struct filter *in_filter, *out_filter; /* Attached filters */ | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /* Protocol-specific data follow... */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | struct proto { | 
					
						
							| 
									
										
										
										
											2000-01-16 23:30:06 +00:00
										 |  |  |   node n;				/* Node in *_proto_list */ | 
					
						
							|  |  |  |   node glob_node;			/* Node in global proto_list */ | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  |   struct protocol *proto;		/* Protocol */ | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  |   struct proto_config *cf;		/* Configuration data */ | 
					
						
							| 
									
										
										
										
											2000-01-16 16:44:50 +00:00
										 |  |  |   struct proto_config *cf_new;		/* Configuration we want to switch to after shutdown (NULL=delete) */ | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  |   pool *pool;				/* Pool containing local objects */ | 
					
						
							| 
									
										
										
										
											1999-02-11 22:45:54 +00:00
										 |  |  |   struct event *attn;			/* "Pay attention" event */ | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-02-11 22:45:54 +00:00
										 |  |  |   char *name;				/* Name of this instance (== cf->name) */ | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  |   unsigned debug;			/* Debugging flags */ | 
					
						
							|  |  |  |   unsigned preference;			/* Default route preference */ | 
					
						
							| 
									
										
										
										
											1999-12-08 14:16:13 +00:00
										 |  |  |   int min_scope;			/* Minimal route scope accepted */ | 
					
						
							| 
									
										
										
										
											1998-11-29 14:40:39 +00:00
										 |  |  |   unsigned disabled;			/* Manually disabled */ | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  |   unsigned proto_state;			/* Protocol state machine (see below) */ | 
					
						
							|  |  |  |   unsigned core_state;			/* Core state machine (see below) */ | 
					
						
							| 
									
										
										
										
											1999-02-11 22:45:54 +00:00
										 |  |  |   unsigned core_goal;			/* State we want to reach (see below) */ | 
					
						
							| 
									
										
										
										
											2000-01-16 16:44:50 +00:00
										 |  |  |   unsigned reconfiguring;		/* We're shutting down due to reconfiguration */ | 
					
						
							| 
									
										
										
										
											1999-12-01 12:00:15 +00:00
										 |  |  |   bird_clock_t last_state_change;	/* Time of last state transition */ | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-04-05 20:17:59 +00:00
										 |  |  |   /*
 | 
					
						
							|  |  |  |    *	General protocol hooks: | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    *	   if_notify	Notify protocol about interface state changes. | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  |    *	   ifa_notify	Notify protocol about interface address changes. | 
					
						
							| 
									
										
										
										
											1999-04-05 20:17:59 +00:00
										 |  |  |    *	   rt_notify	Notify protocol about routing table updates. | 
					
						
							|  |  |  |    *	   neigh_notify	Notify protocol about neighbor cache events. | 
					
						
							|  |  |  |    *	   make_tmp_attrs  Construct ea_list from private attrs stored in rte. | 
					
						
							|  |  |  |    *	   store_tmp_attrs Store private attrs back to the rte. | 
					
						
							|  |  |  |    *	   import_control  Called as the first step of the route importing process. | 
					
						
							|  |  |  |    *			It can construct a new rte, add private attributes and | 
					
						
							|  |  |  |    *			decide whether the route shall be imported: 1=yes, -1=no, | 
					
						
							|  |  |  |    *			0=process it through the import filter set by the user. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  |   void (*if_notify)(struct proto *, unsigned flags, struct iface *i); | 
					
						
							|  |  |  |   void (*ifa_notify)(struct proto *, unsigned flags, struct ifa *a); | 
					
						
							| 
									
										
										
										
											1999-05-31 18:55:35 +00:00
										 |  |  |   void (*rt_notify)(struct proto *, struct network *net, struct rte *new, struct rte *old, struct ea_list *tmpa); | 
					
						
							| 
									
										
										
										
											1998-06-01 21:41:11 +00:00
										 |  |  |   void (*neigh_notify)(struct neighbor *neigh); | 
					
						
							| 
									
										
										
										
											1999-04-05 20:17:59 +00:00
										 |  |  |   struct ea_list *(*make_tmp_attrs)(struct rte *rt, struct linpool *pool); | 
					
						
							|  |  |  |   void (*store_tmp_attrs)(struct rte *rt, struct ea_list *attrs); | 
					
						
							|  |  |  |   int (*import_control)(struct proto *, struct rte **rt, struct ea_list **attrs, struct linpool *pool); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /*
 | 
					
						
							|  |  |  |    *	Routing entry hooks (called only for rte's belonging to this protocol): | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    *	   rte_better	Compare two rte's and decide which one is better (1=first, 0=second). | 
					
						
							|  |  |  |    *	   rte_insert	Called whenever a rte is inserted to a routing table. | 
					
						
							|  |  |  |    *	   rte_remove	Called whenever a rte is removed from the routing table. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-05-20 11:54:33 +00:00
										 |  |  |   int (*rte_better)(struct rte *, struct rte *); | 
					
						
							| 
									
										
										
										
											1998-10-20 15:17:38 +00:00
										 |  |  |   void (*rte_insert)(struct network *, struct rte *); | 
					
						
							|  |  |  |   void (*rte_remove)(struct network *, struct rte *); | 
					
						
							| 
									
										
										
										
											1998-05-20 11:54:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-05-17 20:14:52 +00:00
										 |  |  |   struct rtable *table;			/* Our primary routing table */ | 
					
						
							| 
									
										
										
										
											1999-03-17 14:31:26 +00:00
										 |  |  |   struct filter *in_filter;		/* Input filter */ | 
					
						
							|  |  |  |   struct filter *out_filter;		/* Output filter */ | 
					
						
							| 
									
										
										
										
											1999-05-17 20:14:52 +00:00
										 |  |  |   struct announce_hook *ahooks;		/* Announcement hooks for this protocol */ | 
					
						
							| 
									
										
										
										
											1999-03-17 14:31:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  |   /* Hic sunt protocol-specific data */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  | void proto_build(struct proto_config *); | 
					
						
							|  |  |  | void *proto_new(struct proto_config *, unsigned size); | 
					
						
							|  |  |  | void *proto_config_new(struct protocol *, unsigned size); | 
					
						
							| 
									
										
										
										
											2000-01-16 23:30:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-11-30 12:57:14 +00:00
										 |  |  | void proto_show(struct symbol *, int); | 
					
						
							| 
									
										
										
										
											1999-12-03 11:40:45 +00:00
										 |  |  | struct proto *proto_get_named(struct symbol *, struct protocol *); | 
					
						
							| 
									
										
										
										
											2000-01-16 23:30:06 +00:00
										 |  |  | void proto_xxable(char *, int); | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-01-16 23:30:06 +00:00
										 |  |  | extern list active_proto_list; | 
					
						
							| 
									
										
										
										
											1998-05-20 11:54:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *  Each protocol instance runs two different state machines: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  [P] The protocol machine: (implemented inside protocol) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *		DOWN    ---->    START | 
					
						
							|  |  |  |  *		  ^		   | | 
					
						
							|  |  |  |  *		  |		   V | 
					
						
							|  |  |  |  *		STOP    <----     UP | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	States:	DOWN	Protocol is down and it's waiting for the core | 
					
						
							|  |  |  |  *			requesting protocol start. | 
					
						
							|  |  |  |  *		START	Protocol is waiting for connection with the rest | 
					
						
							|  |  |  |  *			of the network and it's not willing to accept | 
					
						
							|  |  |  |  *			packets. When it connects, it goes to UP state. | 
					
						
							|  |  |  |  *		UP	Protocol is up and running. When the network | 
					
						
							|  |  |  |  *			connection breaks down or the core requests | 
					
						
							|  |  |  |  *			protocol to be terminated, it goes to STOP state. | 
					
						
							|  |  |  |  *		STOP	Protocol is disconnecting from the network. | 
					
						
							|  |  |  |  *			After it disconnects, it returns to DOWN state. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	In:	start()	Called in DOWN state to request protocol startup. | 
					
						
							|  |  |  |  *			Returns new state: either UP or START (in this | 
					
						
							|  |  |  |  *			case, the protocol will notify the core when it | 
					
						
							|  |  |  |  *			finally comes UP). | 
					
						
							|  |  |  |  *		stop()	Called in START, UP or STOP state to request | 
					
						
							|  |  |  |  *			protocol shutdown. Returns new state: either | 
					
						
							|  |  |  |  *			DOWN or STOP (in this case, the protocol will | 
					
						
							|  |  |  |  *			notify the core when it finally comes DOWN). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	Out:	proto_notify_state() -- called by protocol instance when | 
					
						
							|  |  |  |  *			it does any state transition not covered by | 
					
						
							|  |  |  |  *			return values of start() and stop(). This includes | 
					
						
							|  |  |  |  *			START->UP (delayed protocol startup), UP->STOP | 
					
						
							|  |  |  |  *			(spontaneous shutdown) and STOP->DOWN (delayed | 
					
						
							|  |  |  |  *			shutdown). | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PS_DOWN 0
 | 
					
						
							|  |  |  | #define PS_START 1
 | 
					
						
							|  |  |  | #define PS_UP 2
 | 
					
						
							|  |  |  | #define PS_STOP 3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void proto_notify_state(struct proto *p, unsigned state); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *  [F] The feeder machine: (implemented in core routines) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *		HUNGRY    ---->   FEEDING | 
					
						
							|  |  |  |  *		 ^		     | | 
					
						
							|  |  |  |  *		 | 		     V | 
					
						
							|  |  |  |  *		FLUSHING  <----   HAPPY | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	States:	HUNGRY	Protocol either administratively down (i.e., | 
					
						
							|  |  |  |  *			disabled by the user) or temporarily down | 
					
						
							|  |  |  |  *			(i.e., [P] is not UP) | 
					
						
							|  |  |  |  *		FEEDING	The protocol came up and we're feeding it | 
					
						
							|  |  |  |  *			initial routes. [P] is UP. | 
					
						
							|  |  |  |  *		HAPPY	The protocol is up and it's receiving normal | 
					
						
							|  |  |  |  *			routing updates. [P] is UP. | 
					
						
							|  |  |  |  *		FLUSHING The protocol is down and we're removing its | 
					
						
							|  |  |  |  *			routes from the table. [P] is STOP or DOWN. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	Normal lifecycle of a protocol looks like: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *		HUNGRY/DOWN --> HUNGRY/START --> HUNGRY/UP --> | 
					
						
							|  |  |  |  *		FEEDING/UP --> HAPPY/UP --> FLUSHING/STOP|DOWN --> | 
					
						
							|  |  |  |  *		HUNGRY/STOP|DOWN --> HUNGRY/DOWN | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define FS_HUNGRY 0
 | 
					
						
							|  |  |  | #define FS_FEEDING 1
 | 
					
						
							|  |  |  | #define FS_HAPPY 2
 | 
					
						
							|  |  |  | #define FS_FLUSHING 3
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-11-29 22:03:58 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	Known unique protocol instances as referenced by config routines | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-02-05 21:37:34 +00:00
										 |  |  | extern struct proto_config *cf_dev_proto; | 
					
						
							| 
									
										
										
										
											1998-11-29 22:03:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-05-17 20:14:52 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	Route Announcement Hook | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct announce_hook { | 
					
						
							|  |  |  |   node n; | 
					
						
							|  |  |  |   struct rtable *table; | 
					
						
							|  |  |  |   struct proto *proto; | 
					
						
							|  |  |  |   struct announce_hook *next;		/* Next hook for the same protocol */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct announce_hook *proto_add_announce_hook(struct proto *, struct rtable *); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | #endif
 |