net: skb->dst accessors
Define three accessors to get/set dst attached to a skb struct dst_entry *skb_dst(const struct sk_buff *skb) void skb_dst_set(struct sk_buff *skb, struct dst_entry *dst) void skb_dst_drop(struct sk_buff *skb) This one should replace occurrences of : dst_release(skb->dst) skb->dst = NULL; Delete skb->dst field Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
511c3f92ad
commit
adf30907d6
@@ -84,7 +84,7 @@ static u32 flow_get_dst(const struct sk_buff *skb)
|
||||
case htons(ETH_P_IPV6):
|
||||
return ntohl(ipv6_hdr(skb)->daddr.s6_addr32[3]);
|
||||
default:
|
||||
return addr_fold(skb->dst) ^ (__force u16)skb->protocol;
|
||||
return addr_fold(skb_dst(skb)) ^ (__force u16)skb->protocol;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -163,7 +163,7 @@ static u32 flow_get_proto_dst(const struct sk_buff *skb)
|
||||
break;
|
||||
}
|
||||
default:
|
||||
res = addr_fold(skb->dst) ^ (__force u16)skb->protocol;
|
||||
res = addr_fold(skb_dst(skb)) ^ (__force u16)skb->protocol;
|
||||
}
|
||||
|
||||
return res;
|
||||
@@ -251,8 +251,8 @@ fallback:
|
||||
static u32 flow_get_rtclassid(const struct sk_buff *skb)
|
||||
{
|
||||
#ifdef CONFIG_NET_CLS_ROUTE
|
||||
if (skb->dst)
|
||||
return skb->dst->tclassid;
|
||||
if (skb_dst(skb))
|
||||
return skb_dst(skb)->tclassid;
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
@@ -137,7 +137,7 @@ static int route4_classify(struct sk_buff *skb, struct tcf_proto *tp,
|
||||
u32 id, h;
|
||||
int iif, dont_cache = 0;
|
||||
|
||||
if ((dst = skb->dst) == NULL)
|
||||
if ((dst = skb_dst(skb)) == NULL)
|
||||
goto failure;
|
||||
|
||||
id = dst->tclassid;
|
||||
|
@@ -246,11 +246,11 @@ META_COLLECTOR(int_tcindex)
|
||||
|
||||
META_COLLECTOR(int_rtclassid)
|
||||
{
|
||||
if (unlikely(skb->dst == NULL))
|
||||
if (unlikely(skb_dst(skb) == NULL))
|
||||
*err = -1;
|
||||
else
|
||||
#ifdef CONFIG_NET_CLS_ROUTE
|
||||
dst->value = skb->dst->tclassid;
|
||||
dst->value = skb_dst(skb)->tclassid;
|
||||
#else
|
||||
dst->value = 0;
|
||||
#endif
|
||||
|
@@ -149,7 +149,7 @@ static unsigned sfq_hash(struct sfq_sched_data *q, struct sk_buff *skb)
|
||||
break;
|
||||
}
|
||||
default:
|
||||
h = (unsigned long)skb->dst ^ skb->protocol;
|
||||
h = (unsigned long)skb_dst(skb) ^ skb->protocol;
|
||||
h2 = (unsigned long)skb->sk;
|
||||
}
|
||||
|
||||
|
@@ -222,7 +222,7 @@ __teql_resolve(struct sk_buff *skb, struct sk_buff *skb_res, struct net_device *
|
||||
{
|
||||
struct netdev_queue *dev_queue = netdev_get_tx_queue(dev, 0);
|
||||
struct teql_sched_data *q = qdisc_priv(dev_queue->qdisc);
|
||||
struct neighbour *mn = skb->dst->neighbour;
|
||||
struct neighbour *mn = skb_dst(skb)->neighbour;
|
||||
struct neighbour *n = q->ncache;
|
||||
|
||||
if (mn->tbl == NULL)
|
||||
@@ -262,8 +262,8 @@ static inline int teql_resolve(struct sk_buff *skb,
|
||||
return -ENODEV;
|
||||
|
||||
if (dev->header_ops == NULL ||
|
||||
skb->dst == NULL ||
|
||||
skb->dst->neighbour == NULL)
|
||||
skb_dst(skb) == NULL ||
|
||||
skb_dst(skb)->neighbour == NULL)
|
||||
return 0;
|
||||
return __teql_resolve(skb, skb_res, dev);
|
||||
}
|
||||
|
Reference in New Issue
Block a user