mirror of
				https://git.proxmox.com/git/mirror_frr
				synced 2025-10-24 23:02:27 +00:00 
			
		
		
		
	 d62a17aede
			
		
	
	
		d62a17aede
		
	
	
	
	
		
			
			indent.py `git ls-files | pcregrep '\.[ch]$' | pcregrep -v '^(ldpd|babeld|nhrpd)/'` Signed-off-by: David Lamparter <equinox@opensourcerouting.org>
		
			
				
	
	
		
			118 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* BGP-4 Finite State Machine
 | |
|  * From RFC1771 [A Border Gateway Protocol 4 (BGP-4)]
 | |
|  * Copyright (C) 1998 Kunihiro Ishiguro
 | |
|  *
 | |
|  * This file is part of GNU Zebra.
 | |
|  *
 | |
|  * GNU Zebra is free software; you can redistribute it and/or modify it
 | |
|  * under the terms of the GNU General Public License as published by the
 | |
|  * Free Software Foundation; either version 2, or (at your option) any
 | |
|  * later version.
 | |
|  *
 | |
|  * GNU Zebra is distributed in the hope that it will be useful, but
 | |
|  * WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License along
 | |
|  * with this program; see the file COPYING; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
 | |
|  */
 | |
| 
 | |
| #ifndef _QUAGGA_BGP_FSM_H
 | |
| #define _QUAGGA_BGP_FSM_H
 | |
| 
 | |
| /* Macro for BGP read, write and timer thread.  */
 | |
| #define BGP_READ_ON(T, F, V)                                                   \
 | |
| 	do {                                                                   \
 | |
| 		if ((peer->status != Deleted))                                 \
 | |
| 			thread_add_read(bm->master, (F), peer, (V), &(T));     \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_READ_OFF(T)                                                        \
 | |
| 	do {                                                                   \
 | |
| 		if (T)                                                         \
 | |
| 			THREAD_READ_OFF(T);                                    \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_WRITE_ON(T, F, V)                                                  \
 | |
| 	do {                                                                   \
 | |
| 		if ((peer)->status != Deleted)                                 \
 | |
| 			thread_add_write(bm->master, (F), (peer), (V), &(T));  \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_PEER_WRITE_ON(T, F, V, peer)                                       \
 | |
| 	do {                                                                   \
 | |
| 		if ((peer)->status != Deleted)                                 \
 | |
| 			thread_add_write(bm->master, (F), (peer), (V), &(T));  \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_WRITE_OFF(T)                                                       \
 | |
| 	do {                                                                   \
 | |
| 		if (T)                                                         \
 | |
| 			THREAD_WRITE_OFF(T);                                   \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_TIMER_ON(T, F, V)                                                  \
 | |
| 	do {                                                                   \
 | |
| 		if ((peer->status != Deleted))                                 \
 | |
| 			thread_add_timer(bm->master, (F), peer, (V), &(T));    \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_TIMER_OFF(T)                                                       \
 | |
| 	do {                                                                   \
 | |
| 		if (T)                                                         \
 | |
| 			THREAD_TIMER_OFF(T);                                   \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_EVENT_ADD(P, E)                                                    \
 | |
| 	do {                                                                   \
 | |
| 		if ((P)->status != Deleted)                                    \
 | |
| 			thread_add_event(bm->master, bgp_event, (P), (E),      \
 | |
| 					 NULL);                                \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_EVENT_FLUSH(P)                                                     \
 | |
| 	do {                                                                   \
 | |
| 		assert(peer);                                                  \
 | |
| 		thread_cancel_event(bm->master, (P));                          \
 | |
| 	} while (0)
 | |
| 
 | |
| #define BGP_MSEC_JITTER 10
 | |
| 
 | |
| /* Prototypes. */
 | |
| extern void bgp_fsm_nht_update(struct peer *, int valid);
 | |
| extern int bgp_event(struct thread *);
 | |
| extern int bgp_event_update(struct peer *, int event);
 | |
| extern int bgp_stop(struct peer *peer);
 | |
| extern void bgp_timer_set(struct peer *);
 | |
| extern int bgp_routeadv_timer(struct thread *);
 | |
| extern void bgp_fsm_change_status(struct peer *peer, int status);
 | |
| extern const char *peer_down_str[];
 | |
| extern void bgp_update_delay_end(struct bgp *);
 | |
| extern void bgp_maxmed_update(struct bgp *);
 | |
| extern int bgp_maxmed_onstartup_configured(struct bgp *);
 | |
| extern int bgp_maxmed_onstartup_active(struct bgp *);
 | |
| 
 | |
| /**
 | |
|  * Start the route advertisement timer (that honors MRAI) for all the
 | |
|  * peers. Typically called at the end of initial convergence, coming
 | |
|  * out of read-only mode.
 | |
|  */
 | |
| extern void bgp_start_routeadv(struct bgp *);
 | |
| 
 | |
| /**
 | |
|  * See if the route advertisement timer needs to be adjusted for a
 | |
|  * peer. For example, if the last update was written to the peer a
 | |
|  * long while back, we don't need to wait for the periodic advertisement
 | |
|  * timer to expire to send the new set of prefixes. It should fire
 | |
|  * instantly and updates should go out sooner.
 | |
|  */
 | |
| extern void bgp_adjust_routeadv(struct peer *);
 | |
| 
 | |
| #include "hook.h"
 | |
| DECLARE_HOOK(peer_backward_transition, (struct peer * peer), (peer))
 | |
| DECLARE_HOOK(peer_established, (struct peer * peer), (peer))
 | |
| 
 | |
| #endif /* _QUAGGA_BGP_FSM_H */
 |