net: common metrics init helper for dst_entry
authorDavid Ahern <dsahern@gmail.com>
Fri, 5 Oct 2018 03:07:53 +0000 (20:07 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 5 Oct 2018 04:54:19 +0000 (21:54 -0700)
ipv4 and ipv6 both use refcounted metrics if FIB entries have metrics set.
Move the common initialization code to a helper and use for both protocols.

Signed-off-by: David Ahern <dsahern@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/ip.h
net/ipv4/route.c
net/ipv6/route.c

index 8fdd58ce580d6124ded9ba4a9b53b6ceb00a1f70..f9a7125b4bdab3ce91e22d3eb0a5f6c07661ff1a 100644 (file)
@@ -429,6 +429,18 @@ static inline void ip_fib_metrics_put(struct dst_metrics *fib_metrics)
                kfree(fib_metrics);
 }
 
+/* ipv4 and ipv6 both use refcounted metrics if it is not the default */
+static inline
+void ip_dst_init_metrics(struct dst_entry *dst, struct dst_metrics *fib_metrics)
+{
+       dst_init_metrics(dst, fib_metrics->metrics, true);
+
+       if (fib_metrics != &dst_default_metrics) {
+               dst->_metrics |= DST_METRICS_REFCOUNTED;
+               refcount_inc(&fib_metrics->refcnt);
+       }
+}
+
 u32 ip_idents_reserve(u32 hash, int segs);
 void __ip_select_ident(struct net *net, struct iphdr *iph, int segs);
 
index 048919713f4e8aacbf9036b2e42d737f3b492911..8ccbc8f2c2ccf091ccfa42265b1421af8ccc2d07 100644 (file)
@@ -1528,11 +1528,8 @@ static void rt_set_nexthop(struct rtable *rt, __be32 daddr,
                        rt->rt_gateway = nh->nh_gw;
                        rt->rt_uses_gateway = 1;
                }
-               dst_init_metrics(&rt->dst, fi->fib_metrics->metrics, true);
-               if (fi->fib_metrics != &dst_default_metrics) {
-                       rt->dst._metrics |= DST_METRICS_REFCOUNTED;
-                       refcount_inc(&fi->fib_metrics->refcnt);
-               }
+               ip_dst_init_metrics(&rt->dst, fi->fib_metrics);
+
 #ifdef CONFIG_IP_ROUTE_CLASSID
                rt->dst.tclassid = nh->nh_tclassid;
 #endif
index b62b7aa53bbe5b78745095d1a632133f09a0730c..b91a9d3cf28841e4a6c5acd7f940b9fcade6fcd8 100644 (file)
@@ -978,11 +978,7 @@ static void rt6_set_from(struct rt6_info *rt, struct fib6_info *from)
 {
        rt->rt6i_flags &= ~RTF_EXPIRES;
        rcu_assign_pointer(rt->from, from);
-       dst_init_metrics(&rt->dst, from->fib6_metrics->metrics, true);
-       if (from->fib6_metrics != &dst_default_metrics) {
-               rt->dst._metrics |= DST_METRICS_REFCOUNTED;
-               refcount_inc(&from->fib6_metrics->refcnt);
-       }
+       ip_dst_init_metrics(&rt->dst, from->fib6_metrics);
 }
 
 /* Caller must already hold reference to @ort */