xfrm: remove tos indirection from afinfo_policy
authorFlorian Westphal <fw@strlen.de>
Tue, 16 Apr 2019 14:44:37 +0000 (16:44 +0200)
committerSteffen Klassert <steffen.klassert@secunet.com>
Tue, 23 Apr 2019 05:42:20 +0000 (07:42 +0200)
Only used by ipv4, we can read the fl4 tos value directly instead.

Signed-off-by: Florian Westphal <fw@strlen.de>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
include/net/xfrm.h
net/ipv4/xfrm4_policy.c
net/ipv6/xfrm6_policy.c
net/xfrm/xfrm_policy.c

index 77eb578a03844174ef7b5a261abdec54939482be..652da58617726a59e11199b26b865122d2e7725f 100644 (file)
@@ -329,7 +329,6 @@ struct xfrm_policy_afinfo {
        void                    (*decode_session)(struct sk_buff *skb,
                                                  struct flowi *fl,
                                                  int reverse);
-       int                     (*get_tos)(const struct flowi *fl);
        int                     (*init_path)(struct xfrm_dst *path,
                                             struct dst_entry *dst,
                                             int nfheader_len);
index d73a6d6652f60f8b81d47bb36766aa0d0329f3ce..244d26baa3afaaf75b93140a86f4f06fb85ac5eb 100644 (file)
@@ -69,11 +69,6 @@ static int xfrm4_get_saddr(struct net *net, int oif,
        return 0;
 }
 
-static int xfrm4_get_tos(const struct flowi *fl)
-{
-       return IPTOS_RT_MASK & fl->u.ip4.flowi4_tos; /* Strip ECN bits */
-}
-
 static int xfrm4_init_path(struct xfrm_dst *path, struct dst_entry *dst,
                           int nfheader_len)
 {
@@ -272,7 +267,6 @@ static const struct xfrm_policy_afinfo xfrm4_policy_afinfo = {
        .dst_lookup =           xfrm4_dst_lookup,
        .get_saddr =            xfrm4_get_saddr,
        .decode_session =       _decode_session4,
-       .get_tos =              xfrm4_get_tos,
        .init_path =            xfrm4_init_path,
        .fill_dst =             xfrm4_fill_dst,
        .blackhole_route =      ipv4_blackhole_route,
index 769f8f78d3b8955a509cedc1f3823dbb7d3dce44..0e92fa2f96789b6f758c3b68d6ba96db74fde142 100644 (file)
@@ -71,11 +71,6 @@ static int xfrm6_get_saddr(struct net *net, int oif,
        return 0;
 }
 
-static int xfrm6_get_tos(const struct flowi *fl)
-{
-       return 0;
-}
-
 static int xfrm6_init_path(struct xfrm_dst *path, struct dst_entry *dst,
                           int nfheader_len)
 {
@@ -292,7 +287,6 @@ static const struct xfrm_policy_afinfo xfrm6_policy_afinfo = {
        .dst_lookup =           xfrm6_dst_lookup,
        .get_saddr =            xfrm6_get_saddr,
        .decode_session =       _decode_session6,
-       .get_tos =              xfrm6_get_tos,
        .init_path =            xfrm6_init_path,
        .fill_dst =             xfrm6_fill_dst,
        .blackhole_route =      ip6_blackhole_route,
index 16e70fc547b13670a6a1767169bc063ae1921711..1d1335eab76c6adc367d121b130998c905267f18 100644 (file)
@@ -2450,18 +2450,10 @@ xfrm_tmpl_resolve(struct xfrm_policy **pols, int npols, const struct flowi *fl,
 
 static int xfrm_get_tos(const struct flowi *fl, int family)
 {
-       const struct xfrm_policy_afinfo *afinfo;
-       int tos;
-
-       afinfo = xfrm_policy_get_afinfo(family);
-       if (!afinfo)
-               return 0;
-
-       tos = afinfo->get_tos(fl);
+       if (family == AF_INET)
+               return IPTOS_RT_MASK & fl->u.ip4.flowi4_tos;
 
-       rcu_read_unlock();
-
-       return tos;
+       return 0;
 }
 
 static inline struct xfrm_dst *xfrm_alloc_dst(struct net *net, int family)