diff options
Diffstat (limited to 'net/core/skbuff.c')
| -rw-r--r-- | net/core/skbuff.c | 13 | 
1 files changed, 8 insertions, 5 deletions
| diff --git a/net/core/skbuff.c b/net/core/skbuff.c index 974bbbbe7138..417463da4fac 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -91,7 +91,11 @@ static struct kmem_cache *skbuff_ext_cache __ro_after_init;  int sysctl_max_skb_frags __read_mostly = MAX_SKB_FRAGS;  EXPORT_SYMBOL(sysctl_max_skb_frags); -/* The array 'drop_reasons' is auto-generated in dropreason_str.c */ +#undef FN +#define FN(reason) [SKB_DROP_REASON_##reason] = #reason, +const char * const drop_reasons[] = { +	DEFINE_DROP_REASON(FN, FN) +};  EXPORT_SYMBOL(drop_reasons);  /** @@ -4205,9 +4209,8 @@ normal:  				SKB_GSO_CB(nskb)->csum_start =  					skb_headroom(nskb) + doffset;  			} else { -				skb_copy_bits(head_skb, offset, -					      skb_put(nskb, len), -					      len); +				if (skb_copy_bits(head_skb, offset, skb_put(nskb, len), len)) +					goto err;  			}  			continue;  		} @@ -4798,7 +4801,7 @@ static bool skb_may_tx_timestamp(struct sock *sk, bool tsonly)  {  	bool ret; -	if (likely(sysctl_tstamp_allow_data || tsonly)) +	if (likely(READ_ONCE(sysctl_tstamp_allow_data) || tsonly))  		return true;  	read_lock_bh(&sk->sk_callback_lock); | 
