blob: 0387c247f11e382ad2a5f83e64f6ea058ad4bdc3 [file] [log] [blame]
paul718e3742002-12-13 20:15:29 +00001/* BGP routing table
2 Copyright (C) 1998, 2001 Kunihiro Ishiguro
3
4This file is part of GNU Zebra.
5
6GNU Zebra is free software; you can redistribute it and/or modify it
7under the terms of the GNU General Public License as published by the
8Free Software Foundation; either version 2, or (at your option) any
9later version.
10
11GNU Zebra is distributed in the hope that it will be useful, but
12WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with GNU Zebra; see the file COPYING. If not, write to the Free
18Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
1902111-1307, USA. */
20
paul00d252c2005-05-23 14:19:54 +000021#ifndef _QUAGGA_BGP_TABLE_H
22#define _QUAGGA_BGP_TABLE_H
23
paulfee0f4c2004-09-13 05:12:46 +000024typedef enum
25{
26 BGP_TABLE_MAIN,
27 BGP_TABLE_RSCLIENT,
28} bgp_table_t;
29
paul718e3742002-12-13 20:15:29 +000030struct bgp_table
31{
paulfee0f4c2004-09-13 05:12:46 +000032 bgp_table_t type;
Paul Jakma64e580a2006-02-21 01:09:01 +000033
34 /* afi/safi of this table */
35 afi_t afi;
36 safi_t safi;
37
paulfee0f4c2004-09-13 05:12:46 +000038 /* The owner of this 'bgp_table' structure. */
39 void *owner;
40
paul718e3742002-12-13 20:15:29 +000041 struct bgp_node *top;
Paul Jakmacbdfbaa2006-03-30 13:20:48 +000042
43 unsigned long count;
paul718e3742002-12-13 20:15:29 +000044};
45
46struct bgp_node
47{
48 struct prefix p;
49
50 struct bgp_table *table;
51 struct bgp_node *parent;
52 struct bgp_node *link[2];
53#define l_left link[0]
54#define l_right link[1]
55
paul718e3742002-12-13 20:15:29 +000056 void *info;
57
58 struct bgp_adj_out *adj_out;
59
60 struct bgp_adj_in *adj_in;
61
paul718e3742002-12-13 20:15:29 +000062 struct bgp_node *prn;
paul200df112005-06-01 11:17:05 +000063
Paul Jakmacbdfbaa2006-03-30 13:20:48 +000064 unsigned int lock;
65
paul200df112005-06-01 11:17:05 +000066 u_char flags;
67#define BGP_NODE_PROCESS_SCHEDULED (1 << 0)
paul718e3742002-12-13 20:15:29 +000068};
69
Paul Jakma64e580a2006-02-21 01:09:01 +000070extern struct bgp_table *bgp_table_init (afi_t, safi_t);
Paul Jakmab608d5b2008-07-02 02:12:07 +000071extern void bgp_table_finish (struct bgp_table **);
paul94f2b392005-06-28 12:44:16 +000072extern void bgp_unlock_node (struct bgp_node *node);
paul94f2b392005-06-28 12:44:16 +000073extern struct bgp_node *bgp_table_top (struct bgp_table *);
74extern struct bgp_node *bgp_route_next (struct bgp_node *);
75extern struct bgp_node *bgp_route_next_until (struct bgp_node *, struct bgp_node *);
76extern struct bgp_node *bgp_node_get (struct bgp_table *, struct prefix *);
77extern struct bgp_node *bgp_node_lookup (struct bgp_table *, struct prefix *);
78extern struct bgp_node *bgp_lock_node (struct bgp_node *node);
79extern struct bgp_node *bgp_node_match (struct bgp_table *, struct prefix *);
80extern struct bgp_node *bgp_node_match_ipv4 (struct bgp_table *,
paul718e3742002-12-13 20:15:29 +000081 struct in_addr *);
82#ifdef HAVE_IPV6
paul94f2b392005-06-28 12:44:16 +000083extern struct bgp_node *bgp_node_match_ipv6 (struct bgp_table *,
paul718e3742002-12-13 20:15:29 +000084 struct in6_addr *);
85#endif /* HAVE_IPV6 */
Paul Jakmacbdfbaa2006-03-30 13:20:48 +000086extern unsigned long bgp_table_count (struct bgp_table *);
paul00d252c2005-05-23 14:19:54 +000087#endif /* _QUAGGA_BGP_TABLE_H */