diff options
author | David Ahern <dsa@cumulusnetworks.com> | 2016-09-10 22:09:52 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-09-11 09:12:51 +0300 |
commit | 9ee0034b8f49aaaa7e7c2da8db1038915db99c19 (patch) | |
tree | 897ea4c59abca970385ab76daff0add716b32992 /include/net/l3mdev.h | |
parent | cf9932a9414e241571008edd7412ab22f02b5704 (diff) | |
download | linux-9ee0034b8f49aaaa7e7c2da8db1038915db99c19.tar.xz |
net: flow: Add l3mdev flow update
Add l3mdev hook to set FLOWI_FLAG_SKIP_NH_OIF flag and update oif/iif
in flow struct if its oif or iif points to a device enslaved to an L3
Master device. Only 1 needs to be converted to match the l3mdev FIB
rule. This moves the flow adjustment for l3mdev to a single point
catching all lookups. It is redundant for existing hooks (those are
removed in later patches) but is needed for missed lookups such as
PMTU updates.
Signed-off-by: David Ahern <dsa@cumulusnetworks.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/net/l3mdev.h')
-rw-r--r-- | include/net/l3mdev.h | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/include/net/l3mdev.h b/include/net/l3mdev.h index e90095091aa0..81e175e80537 100644 --- a/include/net/l3mdev.h +++ b/include/net/l3mdev.h @@ -49,6 +49,8 @@ struct l3mdev_ops { int l3mdev_fib_rule_match(struct net *net, struct flowi *fl, struct fib_lookup_arg *arg); +void l3mdev_update_flow(struct net *net, struct flowi *fl); + int l3mdev_master_ifindex_rcu(const struct net_device *dev); static inline int l3mdev_master_ifindex(struct net_device *dev) { @@ -290,6 +292,10 @@ int l3mdev_fib_rule_match(struct net *net, struct flowi *fl, { return 1; } +static inline +void l3mdev_update_flow(struct net *net, struct flowi *fl) +{ +} #endif #endif /* _NET_L3MDEV_H_ */ |