diff options
Diffstat (limited to 'drivers/net/ppp')
| -rw-r--r-- | drivers/net/ppp/ppp_async.c | 2 | ||||
| -rw-r--r-- | drivers/net/ppp/ppp_generic.c | 9 | ||||
| -rw-r--r-- | drivers/net/ppp/ppp_synctty.c | 2 | ||||
| -rw-r--r-- | drivers/net/ppp/pppoe.c | 11 | 
4 files changed, 13 insertions, 11 deletions
| diff --git a/drivers/net/ppp/ppp_async.c b/drivers/net/ppp/ppp_async.c index 1b28e6e702f5..bdc4d23627c5 100644 --- a/drivers/net/ppp/ppp_async.c +++ b/drivers/net/ppp/ppp_async.c @@ -334,7 +334,7 @@ ppp_asynctty_ioctl(struct tty_struct *tty, struct file *file,  }  /* No kernel lock - fine */ -static unsigned int +static __poll_t  ppp_asynctty_poll(struct tty_struct *tty, struct file *file, poll_table *wait)  {  	return 0; diff --git a/drivers/net/ppp/ppp_generic.c b/drivers/net/ppp/ppp_generic.c index d8e5747ff4e3..ef6b2126b23a 100644 --- a/drivers/net/ppp/ppp_generic.c +++ b/drivers/net/ppp/ppp_generic.c @@ -531,10 +531,10 @@ static ssize_t ppp_write(struct file *file, const char __user *buf,  }  /* No kernel lock - fine */ -static unsigned int ppp_poll(struct file *file, poll_table *wait) +static __poll_t ppp_poll(struct file *file, poll_table *wait)  {  	struct ppp_file *pf = file->private_data; -	unsigned int mask; +	__poll_t mask;  	if (!pf)  		return 0; @@ -1006,17 +1006,18 @@ static int ppp_unit_register(struct ppp *ppp, int unit, bool ifname_is_set)  	if (!ifname_is_set)  		snprintf(ppp->dev->name, IFNAMSIZ, "ppp%i", ppp->file.index); +	mutex_unlock(&pn->all_ppp_mutex); +  	ret = register_netdevice(ppp->dev);  	if (ret < 0)  		goto err_unit;  	atomic_inc(&ppp_unit_count); -	mutex_unlock(&pn->all_ppp_mutex); -  	return 0;  err_unit: +	mutex_lock(&pn->all_ppp_mutex);  	unit_put(&pn->units_idr, ppp->file.index);  err:  	mutex_unlock(&pn->all_ppp_mutex); diff --git a/drivers/net/ppp/ppp_synctty.c b/drivers/net/ppp/ppp_synctty.c index 7196f00f0991..047f6c68a441 100644 --- a/drivers/net/ppp/ppp_synctty.c +++ b/drivers/net/ppp/ppp_synctty.c @@ -327,7 +327,7 @@ ppp_synctty_ioctl(struct tty_struct *tty, struct file *file,  }  /* No kernel lock - fine */ -static unsigned int +static __poll_t  ppp_sync_poll(struct tty_struct *tty, struct file *file, poll_table *wait)  {  	return 0; diff --git a/drivers/net/ppp/pppoe.c b/drivers/net/ppp/pppoe.c index 4e1da1645b15..5aa59f41bf8c 100644 --- a/drivers/net/ppp/pppoe.c +++ b/drivers/net/ppp/pppoe.c @@ -842,6 +842,7 @@ static int pppoe_sendmsg(struct socket *sock, struct msghdr *m,  	struct pppoe_hdr *ph;  	struct net_device *dev;  	char *start; +	int hlen;  	lock_sock(sk);  	if (sock_flag(sk, SOCK_DEAD) || !(sk->sk_state & PPPOX_CONNECTED)) { @@ -860,16 +861,16 @@ static int pppoe_sendmsg(struct socket *sock, struct msghdr *m,  	if (total_len > (dev->mtu + dev->hard_header_len))  		goto end; - -	skb = sock_wmalloc(sk, total_len + dev->hard_header_len + 32, -			   0, GFP_KERNEL); +	hlen = LL_RESERVED_SPACE(dev); +	skb = sock_wmalloc(sk, hlen + sizeof(*ph) + total_len + +			   dev->needed_tailroom, 0, GFP_KERNEL);  	if (!skb) {  		error = -ENOMEM;  		goto end;  	}  	/* Reserve space for headers. */ -	skb_reserve(skb, dev->hard_header_len); +	skb_reserve(skb, hlen);  	skb_reset_network_header(skb);  	skb->dev = dev; @@ -930,7 +931,7 @@ static int __pppoe_xmit(struct sock *sk, struct sk_buff *skb)  	/* Copy the data if there is no space for the header or if it's  	 * read-only.  	 */ -	if (skb_cow_head(skb, sizeof(*ph) + dev->hard_header_len)) +	if (skb_cow_head(skb, LL_RESERVED_SPACE(dev) + sizeof(*ph)))  		goto abort;  	__skb_push(skb, sizeof(*ph)); | 
