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 | ||
