diff options
Diffstat (limited to 'net/core')
| -rw-r--r-- | net/core/dev.c | 8 | ||||
| -rw-r--r-- | net/core/request_sock.c | 2 | ||||
| -rw-r--r-- | net/core/scm.c | 5 | ||||
| -rw-r--r-- | net/core/skbuff.c | 44 | 
4 files changed, 25 insertions, 34 deletions
diff --git a/net/core/dev.c b/net/core/dev.c index 515473ee52c..f64e439b4a0 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -6121,6 +6121,14 @@ struct netdev_queue *dev_ingress_queue_create(struct net_device *dev)  static const struct ethtool_ops default_ethtool_ops; +void netdev_set_default_ethtool_ops(struct net_device *dev, +				    const struct ethtool_ops *ops) +{ +	if (dev->ethtool_ops == &default_ethtool_ops) +		dev->ethtool_ops = ops; +} +EXPORT_SYMBOL_GPL(netdev_set_default_ethtool_ops); +  /**   *	alloc_netdev_mqs - allocate network device   *	@sizeof_priv:	size of private data to allocate space for diff --git a/net/core/request_sock.c b/net/core/request_sock.c index c31d9e8668c..4425148d2b5 100644 --- a/net/core/request_sock.c +++ b/net/core/request_sock.c @@ -186,8 +186,6 @@ void reqsk_fastopen_remove(struct sock *sk, struct request_sock *req,  	struct fastopen_queue *fastopenq =  	    inet_csk(lsk)->icsk_accept_queue.fastopenq; -	BUG_ON(!spin_is_locked(&sk->sk_lock.slock) && !sock_owned_by_user(sk)); -  	tcp_sk(sk)->fastopen_rsk = NULL;  	spin_lock_bh(&fastopenq->lock);  	fastopenq->qlen--; diff --git a/net/core/scm.c b/net/core/scm.c index 57fb1ee6649..905dcc6ad1e 100644 --- a/net/core/scm.c +++ b/net/core/scm.c @@ -35,6 +35,7 @@  #include <net/sock.h>  #include <net/compat.h>  #include <net/scm.h> +#include <net/cls_cgroup.h>  /* @@ -302,8 +303,10 @@ void scm_detach_fds(struct msghdr *msg, struct scm_cookie *scm)  		}  		/* Bump the usage count and install the file. */  		sock = sock_from_file(fp[i], &err); -		if (sock) +		if (sock) {  			sock_update_netprioidx(sock->sk, current); +			sock_update_classid(sock->sk, current); +		}  		fd_install(new_fd, get_file(fp[i]));  	} diff --git a/net/core/skbuff.c b/net/core/skbuff.c index 3ab989b0de4..a9a2ae3e221 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -1649,7 +1649,7 @@ static void sock_spd_release(struct splice_pipe_desc *spd, unsigned int i)  static struct page *linear_to_page(struct page *page, unsigned int *len,  				   unsigned int *offset, -				   struct sk_buff *skb, struct sock *sk) +				   struct sock *sk)  {  	struct page_frag *pfrag = sk_page_frag(sk); @@ -1682,14 +1682,14 @@ static bool spd_can_coalesce(const struct splice_pipe_desc *spd,  static bool spd_fill_page(struct splice_pipe_desc *spd,  			  struct pipe_inode_info *pipe, struct page *page,  			  unsigned int *len, unsigned int offset, -			  struct sk_buff *skb, bool linear, +			  bool linear,  			  struct sock *sk)  {  	if (unlikely(spd->nr_pages == MAX_SKB_FRAGS))  		return true;  	if (linear) { -		page = linear_to_page(page, len, &offset, skb, sk); +		page = linear_to_page(page, len, &offset, sk);  		if (!page)  			return true;  	} @@ -1706,23 +1706,9 @@ static bool spd_fill_page(struct splice_pipe_desc *spd,  	return false;  } -static inline void __segment_seek(struct page **page, unsigned int *poff, -				  unsigned int *plen, unsigned int off) -{ -	unsigned long n; - -	*poff += off; -	n = *poff / PAGE_SIZE; -	if (n) -		*page = nth_page(*page, n); - -	*poff = *poff % PAGE_SIZE; -	*plen -= off; -} -  static bool __splice_segment(struct page *page, unsigned int poff,  			     unsigned int plen, unsigned int *off, -			     unsigned int *len, struct sk_buff *skb, +			     unsigned int *len,  			     struct splice_pipe_desc *spd, bool linear,  			     struct sock *sk,  			     struct pipe_inode_info *pipe) @@ -1737,23 +1723,19 @@ static bool __splice_segment(struct page *page, unsigned int poff,  	}  	/* ignore any bits we already processed */ -	if (*off) { -		__segment_seek(&page, &poff, &plen, *off); -		*off = 0; -	} +	poff += *off; +	plen -= *off; +	*off = 0;  	do {  		unsigned int flen = min(*len, plen); -		/* the linear region may spread across several pages  */ -		flen = min_t(unsigned int, flen, PAGE_SIZE - poff); - -		if (spd_fill_page(spd, pipe, page, &flen, poff, skb, linear, sk)) +		if (spd_fill_page(spd, pipe, page, &flen, poff, +				  linear, sk))  			return true; - -		__segment_seek(&page, &poff, &plen, flen); +		poff += flen; +		plen -= flen;  		*len -= flen; -  	} while (*len && plen);  	return false; @@ -1777,7 +1759,7 @@ static bool __skb_splice_bits(struct sk_buff *skb, struct pipe_inode_info *pipe,  	if (__splice_segment(virt_to_page(skb->data),  			     (unsigned long) skb->data & (PAGE_SIZE - 1),  			     skb_headlen(skb), -			     offset, len, skb, spd, +			     offset, len, spd,  			     skb_head_is_locked(skb),  			     sk, pipe))  		return true; @@ -1790,7 +1772,7 @@ static bool __skb_splice_bits(struct sk_buff *skb, struct pipe_inode_info *pipe,  		if (__splice_segment(skb_frag_page(f),  				     f->page_offset, skb_frag_size(f), -				     offset, len, skb, spd, false, sk, pipe)) +				     offset, len, spd, false, sk, pipe))  			return true;  	}  |