Commit d93376f5 authored by Martin KaFai Lau's avatar Martin KaFai Lau Committed by David S. Miller

net: Clear mono_delivery_time bit in __skb_tstamp_tx()

In __skb_tstamp_tx(), it may clone the egress skb and queues the clone to
the sk_error_queue.  The outgoing skb may have the mono delivery_time
while the (rcv) timestamp is expected for the clone, so the
skb->mono_delivery_time bit needs to be cleared from the clone.

This patch adds the skb->mono_delivery_time clearing to the existing
__net_timestamp() and use it in __skb_tstamp_tx().
The __net_timestamp() fast path usage in dev.c is changed to directly
call ktime_get_real() since the mono_delivery_time bit is not set at
that point.
Signed-off-by: default avatarMartin KaFai Lau <kafai@fb.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 27942a15
...@@ -3981,6 +3981,7 @@ static inline void skb_get_new_timestampns(const struct sk_buff *skb, ...@@ -3981,6 +3981,7 @@ static inline void skb_get_new_timestampns(const struct sk_buff *skb,
static inline void __net_timestamp(struct sk_buff *skb) static inline void __net_timestamp(struct sk_buff *skb)
{ {
skb->tstamp = ktime_get_real(); skb->tstamp = ktime_get_real();
skb->mono_delivery_time = 0;
} }
static inline ktime_t net_timedelta(ktime_t t) static inline ktime_t net_timedelta(ktime_t t)
......
...@@ -2111,13 +2111,13 @@ static inline void net_timestamp_set(struct sk_buff *skb) ...@@ -2111,13 +2111,13 @@ static inline void net_timestamp_set(struct sk_buff *skb)
skb->tstamp = 0; skb->tstamp = 0;
skb->mono_delivery_time = 0; skb->mono_delivery_time = 0;
if (static_branch_unlikely(&netstamp_needed_key)) if (static_branch_unlikely(&netstamp_needed_key))
__net_timestamp(skb); skb->tstamp = ktime_get_real();
} }
#define net_timestamp_check(COND, SKB) \ #define net_timestamp_check(COND, SKB) \
if (static_branch_unlikely(&netstamp_needed_key)) { \ if (static_branch_unlikely(&netstamp_needed_key)) { \
if ((COND) && !(SKB)->tstamp) \ if ((COND) && !(SKB)->tstamp) \
__net_timestamp(SKB); \ (SKB)->tstamp = ktime_get_real(); \
} \ } \
bool is_skb_forwardable(const struct net_device *dev, const struct sk_buff *skb) bool is_skb_forwardable(const struct net_device *dev, const struct sk_buff *skb)
......
...@@ -4851,7 +4851,7 @@ void __skb_tstamp_tx(struct sk_buff *orig_skb, ...@@ -4851,7 +4851,7 @@ void __skb_tstamp_tx(struct sk_buff *orig_skb,
if (hwtstamps) if (hwtstamps)
*skb_hwtstamps(skb) = *hwtstamps; *skb_hwtstamps(skb) = *hwtstamps;
else else
skb->tstamp = ktime_get_real(); __net_timestamp(skb);
__skb_complete_tx_timestamp(skb, sk, tstype, opt_stats); __skb_complete_tx_timestamp(skb, sk, tstype, opt_stats);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment