diff options
Diffstat (limited to 'include/net/fib_rules.h')
-rw-r--r-- | include/net/fib_rules.h | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/include/net/fib_rules.h b/include/net/fib_rules.h index ca4b2e840078..c07ac9650ebc 100644 --- a/include/net/fib_rules.h +++ b/include/net/fib_rules.h | |||
@@ -7,12 +7,11 @@ | |||
7 | #include <net/flow.h> | 7 | #include <net/flow.h> |
8 | #include <net/rtnetlink.h> | 8 | #include <net/rtnetlink.h> |
9 | 9 | ||
10 | struct fib_rule | 10 | struct fib_rule { |
11 | { | ||
12 | struct list_head list; | 11 | struct list_head list; |
13 | atomic_t refcnt; | 12 | atomic_t refcnt; |
14 | int ifindex; | 13 | int iifindex; |
15 | char ifname[IFNAMSIZ]; | 14 | int oifindex; |
16 | u32 mark; | 15 | u32 mark; |
17 | u32 mark_mask; | 16 | u32 mark_mask; |
18 | u32 pref; | 17 | u32 pref; |
@@ -21,19 +20,19 @@ struct fib_rule | |||
21 | u8 action; | 20 | u8 action; |
22 | u32 target; | 21 | u32 target; |
23 | struct fib_rule * ctarget; | 22 | struct fib_rule * ctarget; |
23 | char iifname[IFNAMSIZ]; | ||
24 | char oifname[IFNAMSIZ]; | ||
24 | struct rcu_head rcu; | 25 | struct rcu_head rcu; |
25 | struct net * fr_net; | 26 | struct net * fr_net; |
26 | }; | 27 | }; |
27 | 28 | ||
28 | struct fib_lookup_arg | 29 | struct fib_lookup_arg { |
29 | { | ||
30 | void *lookup_ptr; | 30 | void *lookup_ptr; |
31 | void *result; | 31 | void *result; |
32 | struct fib_rule *rule; | 32 | struct fib_rule *rule; |
33 | }; | 33 | }; |
34 | 34 | ||
35 | struct fib_rules_ops | 35 | struct fib_rules_ops { |
36 | { | ||
37 | int family; | 36 | int family; |
38 | struct list_head list; | 37 | struct list_head list; |
39 | int rule_size; | 38 | int rule_size; |
@@ -67,10 +66,12 @@ struct fib_rules_ops | |||
67 | struct list_head rules_list; | 66 | struct list_head rules_list; |
68 | struct module *owner; | 67 | struct module *owner; |
69 | struct net *fro_net; | 68 | struct net *fro_net; |
69 | struct rcu_head rcu; | ||
70 | }; | 70 | }; |
71 | 71 | ||
72 | #define FRA_GENERIC_POLICY \ | 72 | #define FRA_GENERIC_POLICY \ |
73 | [FRA_IFNAME] = { .type = NLA_STRING, .len = IFNAMSIZ - 1 }, \ | 73 | [FRA_IIFNAME] = { .type = NLA_STRING, .len = IFNAMSIZ - 1 }, \ |
74 | [FRA_OIFNAME] = { .type = NLA_STRING, .len = IFNAMSIZ - 1 }, \ | ||
74 | [FRA_PRIORITY] = { .type = NLA_U32 }, \ | 75 | [FRA_PRIORITY] = { .type = NLA_U32 }, \ |
75 | [FRA_FWMARK] = { .type = NLA_U32 }, \ | 76 | [FRA_FWMARK] = { .type = NLA_U32 }, \ |
76 | [FRA_FWMASK] = { .type = NLA_U32 }, \ | 77 | [FRA_FWMASK] = { .type = NLA_U32 }, \ |
@@ -102,7 +103,7 @@ static inline u32 frh_get_table(struct fib_rule_hdr *frh, struct nlattr **nla) | |||
102 | return frh->table; | 103 | return frh->table; |
103 | } | 104 | } |
104 | 105 | ||
105 | extern int fib_rules_register(struct fib_rules_ops *); | 106 | extern struct fib_rules_ops *fib_rules_register(struct fib_rules_ops *, struct net *); |
106 | extern void fib_rules_unregister(struct fib_rules_ops *); | 107 | extern void fib_rules_unregister(struct fib_rules_ops *); |
107 | extern void fib_rules_cleanup_ops(struct fib_rules_ops *); | 108 | extern void fib_rules_cleanup_ops(struct fib_rules_ops *); |
108 | 109 | ||