Blame view
include/net/fib_rules.h
2.53 KB
14c0b97dd
|
1 2 3 4 5 6 7 |
#ifndef __NET_FIB_RULES_H #define __NET_FIB_RULES_H #include <linux/types.h> #include <linux/netdevice.h> #include <linux/fib_rules.h> #include <net/flow.h> |
9d9e6a581
|
8 |
#include <net/rtnetlink.h> |
14c0b97dd
|
9 10 11 12 13 14 15 |
struct fib_rule { struct list_head list; atomic_t refcnt; int ifindex; char ifname[IFNAMSIZ]; |
b8964ed9f
|
16 17 |
u32 mark; u32 mark_mask; |
14c0b97dd
|
18 19 20 21 |
u32 pref; u32 flags; u32 table; u8 action; |
0947c9fe5
|
22 23 |
u32 target; struct fib_rule * ctarget; |
14c0b97dd
|
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
struct rcu_head rcu; }; struct fib_lookup_arg { void *lookup_ptr; void *result; struct fib_rule *rule; }; struct fib_rules_ops { int family; struct list_head list; int rule_size; |
e1701c68c
|
39 |
int addr_size; |
0947c9fe5
|
40 41 |
int unresolved_rules; int nr_goto_rules; |
14c0b97dd
|
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
int (*action)(struct fib_rule *, struct flowi *, int, struct fib_lookup_arg *); int (*match)(struct fib_rule *, struct flowi *, int); int (*configure)(struct fib_rule *, struct sk_buff *, struct nlmsghdr *, struct fib_rule_hdr *, struct nlattr **); int (*compare)(struct fib_rule *, struct fib_rule_hdr *, struct nlattr **); int (*fill)(struct fib_rule *, struct sk_buff *, struct nlmsghdr *, struct fib_rule_hdr *); u32 (*default_pref)(void); |
339bf98ff
|
60 |
size_t (*nlmsg_payload)(struct fib_rule *); |
14c0b97dd
|
61 |
|
73417f617
|
62 63 64 |
/* Called after modifications to the rules set, must flush * the route cache if one exists. */ void (*flush_cache)(void); |
14c0b97dd
|
65 |
int nlgroup; |
ef7c79ed6
|
66 |
const struct nla_policy *policy; |
14c0b97dd
|
67 68 69 |
struct list_head *rules_list; struct module *owner; }; |
1f6c9557e
|
70 71 72 73 74 |
#define FRA_GENERIC_POLICY \ [FRA_IFNAME] = { .type = NLA_STRING, .len = IFNAMSIZ - 1 }, \ [FRA_PRIORITY] = { .type = NLA_U32 }, \ [FRA_FWMARK] = { .type = NLA_U32 }, \ [FRA_FWMASK] = { .type = NLA_U32 }, \ |
0947c9fe5
|
75 76 |
[FRA_TABLE] = { .type = NLA_U32 }, \ [FRA_GOTO] = { .type = NLA_U32 } |
1f6c9557e
|
77 |
|
14c0b97dd
|
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 |
static inline void fib_rule_get(struct fib_rule *rule) { atomic_inc(&rule->refcnt); } static inline void fib_rule_put_rcu(struct rcu_head *head) { struct fib_rule *rule = container_of(head, struct fib_rule, rcu); kfree(rule); } static inline void fib_rule_put(struct fib_rule *rule) { if (atomic_dec_and_test(&rule->refcnt)) call_rcu(&rule->rcu, fib_rule_put_rcu); } |
9e762a4a8
|
94 95 96 97 98 99 |
static inline u32 frh_get_table(struct fib_rule_hdr *frh, struct nlattr **nla) { if (nla[FRA_TABLE]) return nla_get_u32(nla[FRA_TABLE]); return frh->table; } |
14c0b97dd
|
100 101 102 103 104 105 |
extern int fib_rules_register(struct fib_rules_ops *); extern int fib_rules_unregister(struct fib_rules_ops *); extern int fib_rules_lookup(struct fib_rules_ops *, struct flowi *, int flags, struct fib_lookup_arg *); |
14c0b97dd
|
106 |
#endif |