Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | #ifndef _FIB_LOOKUP_H |
| 3 | #define _FIB_LOOKUP_H |
| 4 | |
| 5 | #include <linux/types.h> |
| 6 | #include <linux/list.h> |
| 7 | #include <net/ip_fib.h> |
David Ahern | 5481d73 | 2019-06-03 20:19:49 -0700 | [diff] [blame] | 8 | #include <net/nexthop.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 9 | |
| 10 | struct fib_alias { |
Alexander Duyck | 56315f9 | 2015-02-25 15:31:31 -0800 | [diff] [blame] | 11 | struct hlist_node fa_list; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 12 | struct fib_info *fa_info; |
| 13 | u8 fa_tos; |
| 14 | u8 fa_type; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 15 | u8 fa_state; |
Alexander Duyck | 9b6ebad | 2015-02-25 15:31:44 -0800 | [diff] [blame] | 16 | u8 fa_slen; |
Alexander Duyck | 0ddcf43 | 2015-03-06 13:47:00 -0800 | [diff] [blame] | 17 | u32 tb_id; |
Julian Anastasov | 2392deb | 2015-07-22 10:43:23 +0300 | [diff] [blame] | 18 | s16 fa_default; |
Eric Dumazet | a6501e0 | 2008-01-18 03:33:26 -0800 | [diff] [blame] | 19 | struct rcu_head rcu; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 20 | }; |
| 21 | |
| 22 | #define FA_S_ACCESSED 0x01 |
| 23 | |
Eric Dumazet | 9b0c290 | 2010-10-20 22:03:38 +0000 | [diff] [blame] | 24 | /* Dont write on fa_state unless needed, to keep it shared on all cpus */ |
| 25 | static inline void fib_alias_accessed(struct fib_alias *fa) |
| 26 | { |
| 27 | if (!(fa->fa_state & FA_S_ACCESSED)) |
| 28 | fa->fa_state |= FA_S_ACCESSED; |
| 29 | } |
| 30 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | /* Exported by fib_semantics.c */ |
Joe Perches | 7e58487 | 2013-10-18 13:48:24 -0700 | [diff] [blame] | 32 | void fib_release_info(struct fib_info *); |
David Ahern | 6d8422a1 | 2017-05-21 10:12:02 -0600 | [diff] [blame] | 33 | struct fib_info *fib_create_info(struct fib_config *cfg, |
| 34 | struct netlink_ext_ack *extack); |
David Ahern | 9ae2872 | 2017-05-27 16:19:28 -0600 | [diff] [blame] | 35 | int fib_nh_match(struct fib_config *cfg, struct fib_info *fi, |
| 36 | struct netlink_ext_ack *extack); |
Xin Long | 5f9ae3d | 2017-08-23 10:07:26 +0800 | [diff] [blame] | 37 | bool fib_metrics_match(struct fib_config *cfg, struct fib_info *fi); |
Joe Perches | 7e58487 | 2013-10-18 13:48:24 -0700 | [diff] [blame] | 38 | int fib_dump_info(struct sk_buff *skb, u32 pid, u32 seq, int event, u32 tb_id, |
| 39 | u8 type, __be32 dst, int dst_len, u8 tos, struct fib_info *fi, |
| 40 | unsigned int); |
| 41 | void rtmsg_fib(int event, __be32 key, struct fib_alias *fa, int dst_len, |
| 42 | u32 tb_id, const struct nl_info *info, unsigned int nlm_flags); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 43 | |
Denis V. Lunev | a2bbe68 | 2007-12-08 00:31:44 -0800 | [diff] [blame] | 44 | static inline void fib_result_assign(struct fib_result *res, |
| 45 | struct fib_info *fi) |
| 46 | { |
Eric Dumazet | 1f1b9c9 | 2010-11-04 01:21:39 +0000 | [diff] [blame] | 47 | /* we used to play games with refcounts, but we now use RCU */ |
Denis V. Lunev | a2bbe68 | 2007-12-08 00:31:44 -0800 | [diff] [blame] | 48 | res->fi = fi; |
David Ahern | eba618a | 2019-04-02 14:11:55 -0700 | [diff] [blame] | 49 | res->nhc = fib_info_nhc(fi, 0); |
Denis V. Lunev | a2bbe68 | 2007-12-08 00:31:44 -0800 | [diff] [blame] | 50 | } |
| 51 | |
David S. Miller | 3be0686 | 2011-03-07 15:01:10 -0800 | [diff] [blame] | 52 | struct fib_prop { |
| 53 | int error; |
| 54 | u8 scope; |
| 55 | }; |
| 56 | |
| 57 | extern const struct fib_prop fib_props[RTN_MAX + 1]; |
| 58 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 59 | #endif /* _FIB_LOOKUP_H */ |