blob: e13022bb9e595958ce8f0032551c10aca6437a45 [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;
42};
43
44struct bgp_node
45{
46 struct prefix p;
47
48 struct bgp_table *table;
49 struct bgp_node *parent;
50 struct bgp_node *link[2];
51#define l_left link[0]
52#define l_right link[1]
53
54 unsigned int lock;
55
56 void *info;
57
58 struct bgp_adj_out *adj_out;
59
60 struct bgp_adj_in *adj_in;
61
62 void *aggregate;
63
64 struct bgp_node *prn;
paul200df112005-06-01 11:17:05 +000065
66 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);
paul94f2b392005-06-28 12:44:16 +000071extern void bgp_table_finish (struct bgp_table *);
72extern void bgp_unlock_node (struct bgp_node *node);
73extern void bgp_node_delete (struct bgp_node *node);
74extern struct bgp_node *bgp_table_top (struct bgp_table *);
75extern struct bgp_node *bgp_route_next (struct bgp_node *);
76extern struct bgp_node *bgp_route_next_until (struct bgp_node *, struct bgp_node *);
77extern struct bgp_node *bgp_node_get (struct bgp_table *, struct prefix *);
78extern struct bgp_node *bgp_node_lookup (struct bgp_table *, struct prefix *);
79extern struct bgp_node *bgp_lock_node (struct bgp_node *node);
80extern struct bgp_node *bgp_node_match (struct bgp_table *, struct prefix *);
81extern struct bgp_node *bgp_node_match_ipv4 (struct bgp_table *,
paul718e3742002-12-13 20:15:29 +000082 struct in_addr *);
83#ifdef HAVE_IPV6
paul94f2b392005-06-28 12:44:16 +000084extern struct bgp_node *bgp_node_match_ipv6 (struct bgp_table *,
paul718e3742002-12-13 20:15:29 +000085 struct in6_addr *);
86#endif /* HAVE_IPV6 */
paul00d252c2005-05-23 14:19:54 +000087
88#endif /* _QUAGGA_BGP_TABLE_H */