| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
 | 2 |  *	Linux INET6 implementation  | 
 | 3 |  * | 
 | 4 |  *	Authors: | 
 | 5 |  *	Pedro Roque		<roque@di.fc.ul.pt>	 | 
 | 6 |  * | 
 | 7 |  *	This program is free software; you can redistribute it and/or | 
 | 8 |  *      modify it under the terms of the GNU General Public License | 
 | 9 |  *      as published by the Free Software Foundation; either version | 
 | 10 |  *      2 of the License, or (at your option) any later version. | 
 | 11 |  */ | 
 | 12 |  | 
 | 13 | #ifndef _IP6_FIB_H | 
 | 14 | #define _IP6_FIB_H | 
 | 15 |  | 
 | 16 | #ifdef __KERNEL__ | 
 | 17 |  | 
 | 18 | #include <linux/ipv6_route.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 | #include <linux/rtnetlink.h> | 
 | 20 | #include <linux/spinlock.h> | 
| Thomas Graf | 86872cb | 2006-08-22 00:01:08 -0700 | [diff] [blame] | 21 | #include <net/dst.h> | 
 | 22 | #include <net/flow.h> | 
 | 23 | #include <net/netlink.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 |  | 
| Neil Horman | a33bc5c | 2009-07-30 18:52:15 -0700 | [diff] [blame] | 25 | #ifdef CONFIG_IPV6_MULTIPLE_TABLES | 
 | 26 | #define FIB6_TABLE_HASHSZ 256 | 
 | 27 | #else | 
 | 28 | #define FIB6_TABLE_HASHSZ 1 | 
 | 29 | #endif | 
 | 30 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | struct rt6_info; | 
 | 32 |  | 
| Thomas Graf | 86872cb | 2006-08-22 00:01:08 -0700 | [diff] [blame] | 33 | struct fib6_config | 
 | 34 | { | 
 | 35 | 	u32		fc_table; | 
 | 36 | 	u32		fc_metric; | 
 | 37 | 	int		fc_dst_len; | 
 | 38 | 	int		fc_src_len; | 
 | 39 | 	int		fc_ifindex; | 
 | 40 | 	u32		fc_flags; | 
 | 41 | 	u32		fc_protocol; | 
 | 42 |  | 
 | 43 | 	struct in6_addr	fc_dst; | 
 | 44 | 	struct in6_addr	fc_src; | 
 | 45 | 	struct in6_addr	fc_gateway; | 
 | 46 |  | 
 | 47 | 	unsigned long	fc_expires; | 
 | 48 | 	struct nlattr	*fc_mx; | 
 | 49 | 	int		fc_mx_len; | 
 | 50 |  | 
 | 51 | 	struct nl_info	fc_nlinfo; | 
 | 52 | }; | 
 | 53 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 54 | struct fib6_node | 
 | 55 | { | 
 | 56 | 	struct fib6_node	*parent; | 
 | 57 | 	struct fib6_node	*left; | 
 | 58 | 	struct fib6_node	*right; | 
| Kim Nordlund | 8bce65b | 2006-12-13 16:38:29 -0800 | [diff] [blame] | 59 | #ifdef CONFIG_IPV6_SUBTREES | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 60 | 	struct fib6_node	*subtree; | 
| Kim Nordlund | 8bce65b | 2006-12-13 16:38:29 -0800 | [diff] [blame] | 61 | #endif | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 62 | 	struct rt6_info		*leaf; | 
 | 63 |  | 
 | 64 | 	__u16			fn_bit;		/* bit key */ | 
 | 65 | 	__u16			fn_flags; | 
 | 66 | 	__u32			fn_sernum; | 
| David S. Miller | f11e665 | 2007-03-24 20:36:25 -0700 | [diff] [blame] | 67 | 	struct rt6_info		*rr_ptr; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 68 | }; | 
 | 69 |  | 
| YOSHIFUJI Hideaki | 7fc3316 | 2006-08-23 17:22:24 -0700 | [diff] [blame] | 70 | #ifndef CONFIG_IPV6_SUBTREES | 
 | 71 | #define FIB6_SUBTREE(fn)	NULL | 
 | 72 | #else | 
 | 73 | #define FIB6_SUBTREE(fn)	((fn)->subtree) | 
 | 74 | #endif | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 75 |  | 
 | 76 | /* | 
 | 77 |  *	routing information | 
 | 78 |  * | 
 | 79 |  */ | 
 | 80 |  | 
 | 81 | struct rt6key | 
 | 82 | { | 
 | 83 | 	struct in6_addr	addr; | 
 | 84 | 	int		plen; | 
 | 85 | }; | 
 | 86 |  | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 87 | struct fib6_table; | 
 | 88 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 89 | struct rt6_info | 
 | 90 | { | 
 | 91 | 	union { | 
 | 92 | 		struct dst_entry	dst; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 93 | 	} u; | 
 | 94 |  | 
 | 95 | 	struct inet6_dev		*rt6i_idev; | 
 | 96 |  | 
 | 97 | #define rt6i_dev			u.dst.dev | 
 | 98 | #define rt6i_nexthop			u.dst.neighbour | 
 | 99 | #define rt6i_expires			u.dst.expires | 
 | 100 |  | 
 | 101 | 	struct fib6_node		*rt6i_node; | 
 | 102 |  | 
 | 103 | 	struct in6_addr			rt6i_gateway; | 
 | 104 | 	 | 
 | 105 | 	u32				rt6i_flags; | 
 | 106 | 	u32				rt6i_metric; | 
 | 107 | 	atomic_t			rt6i_ref; | 
| Herbert Xu | b4ce927 | 2007-11-13 21:33:32 -0800 | [diff] [blame] | 108 |  | 
 | 109 | 	/* more non-fragment space at head required */ | 
| Masahide NAKAMURA | a1b0514 | 2007-12-20 20:41:12 -0800 | [diff] [blame] | 110 | 	unsigned short			rt6i_nfheader_len; | 
| Herbert Xu | b4ce927 | 2007-11-13 21:33:32 -0800 | [diff] [blame] | 111 |  | 
 | 112 | 	u8				rt6i_protocol; | 
 | 113 |  | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 114 | 	struct fib6_table		*rt6i_table; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 115 |  | 
 | 116 | 	struct rt6key			rt6i_dst; | 
| Noriaki TAKAMIYA | a47ed4c | 2007-09-06 03:31:25 -0700 | [diff] [blame] | 117 |  | 
 | 118 | #ifdef CONFIG_XFRM | 
 | 119 | 	u32				rt6i_flow_cache_genid; | 
 | 120 | #endif | 
| Herbert Xu | b4ce927 | 2007-11-13 21:33:32 -0800 | [diff] [blame] | 121 |  | 
 | 122 | 	struct rt6key			rt6i_src; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 123 | }; | 
 | 124 |  | 
| YOSHIFUJI Hideaki | 7a3025b | 2006-10-13 16:17:25 +0900 | [diff] [blame] | 125 | static inline struct inet6_dev *ip6_dst_idev(struct dst_entry *dst) | 
 | 126 | { | 
 | 127 | 	return ((struct rt6_info *)dst)->rt6i_idev; | 
 | 128 | } | 
 | 129 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 130 | struct fib6_walker_t | 
 | 131 | { | 
 | 132 | 	struct fib6_walker_t *prev, *next; | 
 | 133 | 	struct fib6_node *root, *node; | 
 | 134 | 	struct rt6_info *leaf; | 
 | 135 | 	unsigned char state; | 
 | 136 | 	unsigned char prune; | 
 | 137 | 	int (*func)(struct fib6_walker_t *); | 
 | 138 | 	void *args; | 
 | 139 | }; | 
 | 140 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 141 | struct rt6_statistics { | 
 | 142 | 	__u32		fib_nodes; | 
 | 143 | 	__u32		fib_route_nodes; | 
 | 144 | 	__u32		fib_rt_alloc;		/* permanent routes	*/ | 
 | 145 | 	__u32		fib_rt_entries;		/* rt entries in table	*/ | 
 | 146 | 	__u32		fib_rt_cache;		/* cache routes		*/ | 
 | 147 | 	__u32		fib_discarded_routes; | 
 | 148 | }; | 
 | 149 |  | 
 | 150 | #define RTN_TL_ROOT	0x0001 | 
 | 151 | #define RTN_ROOT	0x0002		/* tree root node		*/ | 
 | 152 | #define RTN_RTINFO	0x0004		/* node with valid routing info	*/ | 
 | 153 |  | 
 | 154 | /* | 
 | 155 |  *	priority levels (or metrics) | 
 | 156 |  * | 
 | 157 |  */ | 
 | 158 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 159 |  | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 160 | struct fib6_table { | 
 | 161 | 	struct hlist_node	tb6_hlist; | 
 | 162 | 	u32			tb6_id; | 
 | 163 | 	rwlock_t		tb6_lock; | 
 | 164 | 	struct fib6_node	tb6_root; | 
 | 165 | }; | 
 | 166 |  | 
 | 167 | #define RT6_TABLE_UNSPEC	RT_TABLE_UNSPEC | 
 | 168 | #define RT6_TABLE_MAIN		RT_TABLE_MAIN | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 169 | #define RT6_TABLE_DFLT		RT6_TABLE_MAIN | 
 | 170 | #define RT6_TABLE_INFO		RT6_TABLE_MAIN | 
 | 171 | #define RT6_TABLE_PREFIX	RT6_TABLE_MAIN | 
 | 172 |  | 
 | 173 | #ifdef CONFIG_IPV6_MULTIPLE_TABLES | 
 | 174 | #define FIB6_TABLE_MIN		1 | 
 | 175 | #define FIB6_TABLE_MAX		RT_TABLE_MAX | 
| Thomas Graf | 101367c | 2006-08-04 03:39:02 -0700 | [diff] [blame] | 176 | #define RT6_TABLE_LOCAL		RT_TABLE_LOCAL | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 177 | #else | 
 | 178 | #define FIB6_TABLE_MIN		RT_TABLE_MAIN | 
 | 179 | #define FIB6_TABLE_MAX		FIB6_TABLE_MIN | 
| Thomas Graf | 101367c | 2006-08-04 03:39:02 -0700 | [diff] [blame] | 180 | #define RT6_TABLE_LOCAL		RT6_TABLE_MAIN | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 181 | #endif | 
 | 182 |  | 
| Daniel Lezcano | 8ed6778 | 2008-03-04 13:48:30 -0800 | [diff] [blame] | 183 | typedef struct rt6_info *(*pol_lookup_t)(struct net *, | 
 | 184 | 					 struct fib6_table *, | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 185 | 					 struct flowi *, int); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 186 |  | 
 | 187 | /* | 
 | 188 |  *	exported functions | 
 | 189 |  */ | 
 | 190 |  | 
| Daniel Lezcano | 58f09b7 | 2008-03-03 23:25:27 -0800 | [diff] [blame] | 191 | extern struct fib6_table        *fib6_get_table(struct net *net, u32 id); | 
 | 192 | extern struct fib6_table        *fib6_new_table(struct net *net, u32 id); | 
 | 193 | extern struct dst_entry         *fib6_rule_lookup(struct net *net, | 
 | 194 | 						  struct flowi *fl, int flags, | 
 | 195 | 						  pol_lookup_t lookup); | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 196 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 197 | extern struct fib6_node		*fib6_lookup(struct fib6_node *root, | 
 | 198 | 					     struct in6_addr *daddr, | 
 | 199 | 					     struct in6_addr *saddr); | 
 | 200 |  | 
 | 201 | struct fib6_node		*fib6_locate(struct fib6_node *root, | 
 | 202 | 					     struct in6_addr *daddr, int dst_len, | 
 | 203 | 					     struct in6_addr *saddr, int src_len); | 
 | 204 |  | 
| Daniel Lezcano | f3db485 | 2008-03-03 23:27:06 -0800 | [diff] [blame] | 205 | extern void			fib6_clean_all(struct net *net, | 
 | 206 | 					       int (*func)(struct rt6_info *, void *arg), | 
| Thomas Graf | c71099a | 2006-08-04 23:20:06 -0700 | [diff] [blame] | 207 | 					       int prune, void *arg); | 
 | 208 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 209 | extern int			fib6_add(struct fib6_node *root, | 
 | 210 | 					 struct rt6_info *rt, | 
| Thomas Graf | 86872cb | 2006-08-22 00:01:08 -0700 | [diff] [blame] | 211 | 					 struct nl_info *info); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 212 |  | 
 | 213 | extern int			fib6_del(struct rt6_info *rt, | 
| Thomas Graf | 86872cb | 2006-08-22 00:01:08 -0700 | [diff] [blame] | 214 | 					 struct nl_info *info); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 215 |  | 
 | 216 | extern void			inet6_rt_notify(int event, struct rt6_info *rt, | 
| Thomas Graf | 86872cb | 2006-08-22 00:01:08 -0700 | [diff] [blame] | 217 | 						struct nl_info *info); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 218 |  | 
| Daniel Lezcano | 5b7c931 | 2008-03-03 23:28:58 -0800 | [diff] [blame] | 219 | extern void			fib6_run_gc(unsigned long expires, | 
 | 220 | 					    struct net *net); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 221 |  | 
 | 222 | extern void			fib6_gc_cleanup(void); | 
 | 223 |  | 
| Daniel Lezcano | d63bddb | 2007-12-07 00:40:34 -0800 | [diff] [blame] | 224 | extern int			fib6_init(void); | 
| Thomas Graf | 101367c | 2006-08-04 03:39:02 -0700 | [diff] [blame] | 225 |  | 
| Daniel Lezcano | 7e5449c | 2007-12-08 00:14:54 -0800 | [diff] [blame] | 226 | #ifdef CONFIG_IPV6_MULTIPLE_TABLES | 
| Daniel Lezcano | 9eb87f3 | 2007-12-07 00:42:52 -0800 | [diff] [blame] | 227 | extern int			fib6_rules_init(void); | 
| Thomas Graf | 101367c | 2006-08-04 03:39:02 -0700 | [diff] [blame] | 228 | extern void			fib6_rules_cleanup(void); | 
| Daniel Lezcano | 7e5449c | 2007-12-08 00:14:54 -0800 | [diff] [blame] | 229 | #else | 
 | 230 | static inline int               fib6_rules_init(void) | 
 | 231 | { | 
 | 232 | 	return 0; | 
 | 233 | } | 
 | 234 | static inline void              fib6_rules_cleanup(void) | 
 | 235 | { | 
 | 236 | 	return ; | 
 | 237 | } | 
 | 238 | #endif | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 239 | #endif | 
 | 240 | #endif |