net: ipv6: use common fib_default_rule_pref
This switches IPv6 policy routing to use the shared fib_default_rule_pref() function of IPv4 and DECnet. It is also used in multicast routing for IPv4 as well as IPv6. The motivation for this patch is a complaint about iproute2 behaving inconsistent between IPv4 and IPv6 when adding policy rules: Formerly, IPv6 rules were assigned a fixed priority of 0x3FFF whereas for IPv4 the assigned priority value was decreased with each rule added. Since then all users of the default_pref field have been converted to assign the generic function fib_default_rule_pref(), fib_nl_newrule() may just use it directly instead. Therefore get rid of the function pointer altogether and make fib_default_rule_pref() static, as it's not used outside fib_rules.c anymore. Signed-off-by: Phil Sutter <phil@nwl.cc> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
444c5f92ed
commit
f53de1e9a4
@@ -66,7 +66,6 @@ struct fib_rules_ops {
|
||||
struct nlattr **);
|
||||
int (*fill)(struct fib_rule *, struct sk_buff *,
|
||||
struct fib_rule_hdr *);
|
||||
u32 (*default_pref)(struct fib_rules_ops *ops);
|
||||
size_t (*nlmsg_payload)(struct fib_rule *);
|
||||
|
||||
/* Called after modifications to the rules set, must flush
|
||||
@@ -118,5 +117,4 @@ int fib_rules_lookup(struct fib_rules_ops *, struct flowi *, int flags,
|
||||
struct fib_lookup_arg *);
|
||||
int fib_default_rule_add(struct fib_rules_ops *, u32 pref, u32 table,
|
||||
u32 flags);
|
||||
u32 fib_default_rule_pref(struct fib_rules_ops *ops);
|
||||
#endif
|
||||
|
Reference in New Issue
Block a user