diff options
Diffstat (limited to 'net/unix/af_unix.c')
| -rw-r--r-- | net/unix/af_unix.c | 49 | 
1 files changed, 12 insertions, 37 deletions
| diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c index 1a0c961f4ffe..7f46bab4ce5c 100644 --- a/net/unix/af_unix.c +++ b/net/unix/af_unix.c @@ -212,7 +212,7 @@ EXPORT_SYMBOL_GPL(unix_peer_get);  static inline void unix_release_addr(struct unix_address *addr)  { -	if (atomic_dec_and_test(&addr->refcnt)) +	if (refcount_dec_and_test(&addr->refcnt))  		kfree(addr);  } @@ -343,7 +343,7 @@ found:   * are still connected to it and there's no way to inform "a polling   * implementation" that it should let go of a certain wait queue   * - * In order to propagate a wake up, a wait_queue_t of the client + * In order to propagate a wake up, a wait_queue_entry_t of the client   * socket is enqueued on the peer_wait queue of the server socket   * whose wake function does a wake_up on the ordinary client socket   * wait queue. This connection is established whenever a write (or @@ -352,7 +352,7 @@ found:   * was relayed.   */ -static int unix_dgram_peer_wake_relay(wait_queue_t *q, unsigned mode, int flags, +static int unix_dgram_peer_wake_relay(wait_queue_entry_t *q, unsigned mode, int flags,  				      void *key)  {  	struct unix_sock *u; @@ -442,7 +442,7 @@ static int unix_dgram_peer_wake_me(struct sock *sk, struct sock *other)  static int unix_writable(const struct sock *sk)  {  	return sk->sk_state != TCP_LISTEN && -	       (atomic_read(&sk->sk_wmem_alloc) << 2) <= sk->sk_sndbuf; +	       (refcount_read(&sk->sk_wmem_alloc) << 2) <= sk->sk_sndbuf;  }  static void unix_write_space(struct sock *sk) @@ -487,7 +487,7 @@ static void unix_sock_destructor(struct sock *sk)  	skb_queue_purge(&sk->sk_receive_queue); -	WARN_ON(atomic_read(&sk->sk_wmem_alloc)); +	WARN_ON(refcount_read(&sk->sk_wmem_alloc));  	WARN_ON(!sk_unhashed(sk));  	WARN_ON(sk->sk_socket);  	if (!sock_flag(sk, SOCK_DEAD)) { @@ -864,7 +864,7 @@ static int unix_autobind(struct socket *sock)  		goto out;  	addr->name->sun_family = AF_UNIX; -	atomic_set(&addr->refcnt, 1); +	refcount_set(&addr->refcnt, 1);  retry:  	addr->len = sprintf(addr->name->sun_path+1, "%05x", ordernum) + 1 + sizeof(short); @@ -1040,7 +1040,7 @@ static int unix_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len)  	memcpy(addr->name, sunaddr, addr_len);  	addr->len = addr_len;  	addr->hash = hash ^ sk->sk_type; -	atomic_set(&addr->refcnt, 1); +	refcount_set(&addr->refcnt, 1);  	if (sun_path[0]) {  		addr->hash = UNIX_HASH_SIZE; @@ -1335,7 +1335,7 @@ restart:  	/* copy address information from listening to new sock*/  	if (otheru->addr) { -		atomic_inc(&otheru->addr->refcnt); +		refcount_inc(&otheru->addr->refcnt);  		newu->addr = otheru->addr;  	}  	if (otheru->path.dentry) { @@ -1528,26 +1528,13 @@ static inline bool too_many_unix_fds(struct task_struct *p)  	return false;  } -#define MAX_RECURSION_LEVEL 4 -  static int unix_attach_fds(struct scm_cookie *scm, struct sk_buff *skb)  {  	int i; -	unsigned char max_level = 0;  	if (too_many_unix_fds(current))  		return -ETOOMANYREFS; -	for (i = scm->fp->count - 1; i >= 0; i--) { -		struct sock *sk = unix_get_socket(scm->fp->fp[i]); - -		if (sk) -			max_level = max(max_level, -					unix_sk(sk)->recursion_level); -	} -	if (unlikely(max_level > MAX_RECURSION_LEVEL)) -		return -ETOOMANYREFS; -  	/*  	 * Need to duplicate file references for the sake of garbage  	 * collection.  Otherwise a socket in the fps might become a @@ -1559,7 +1546,7 @@ static int unix_attach_fds(struct scm_cookie *scm, struct sk_buff *skb)  	for (i = scm->fp->count - 1; i >= 0; i--)  		unix_inflight(scm->fp->user, scm->fp->fp[i]); -	return max_level; +	return 0;  }  static int unix_scm_to_skb(struct scm_cookie *scm, struct sk_buff *skb, bool send_fds) @@ -1649,7 +1636,6 @@ static int unix_dgram_sendmsg(struct socket *sock, struct msghdr *msg,  	struct sk_buff *skb;  	long timeo;  	struct scm_cookie scm; -	int max_level;  	int data_len = 0;  	int sk_locked; @@ -1701,7 +1687,6 @@ static int unix_dgram_sendmsg(struct socket *sock, struct msghdr *msg,  	err = unix_scm_to_skb(&scm, skb, true);  	if (err < 0)  		goto out_free; -	max_level = err + 1;  	skb_put(skb, len - data_len);  	skb->data_len = data_len; @@ -1819,8 +1804,6 @@ restart_locked:  		__net_timestamp(skb);  	maybe_add_creds(skb, sock, other);  	skb_queue_tail(&other->sk_receive_queue, skb); -	if (max_level > unix_sk(other)->recursion_level) -		unix_sk(other)->recursion_level = max_level;  	unix_state_unlock(other);  	other->sk_data_ready(other);  	sock_put(other); @@ -1855,7 +1838,6 @@ static int unix_stream_sendmsg(struct socket *sock, struct msghdr *msg,  	int sent = 0;  	struct scm_cookie scm;  	bool fds_sent = false; -	int max_level;  	int data_len;  	wait_for_unix_gc(); @@ -1905,7 +1887,6 @@ static int unix_stream_sendmsg(struct socket *sock, struct msghdr *msg,  			kfree_skb(skb);  			goto out_err;  		} -		max_level = err + 1;  		fds_sent = true;  		skb_put(skb, size - data_len); @@ -1925,8 +1906,6 @@ static int unix_stream_sendmsg(struct socket *sock, struct msghdr *msg,  		maybe_add_creds(skb, sock, other);  		skb_queue_tail(&other->sk_receive_queue, skb); -		if (max_level > unix_sk(other)->recursion_level) -			unix_sk(other)->recursion_level = max_level;  		unix_state_unlock(other);  		other->sk_data_ready(other);  		sent += size; @@ -2033,7 +2012,7 @@ alloc_skb:  	skb->len += size;  	skb->data_len += size;  	skb->truesize += size; -	atomic_add(size, &sk->sk_wmem_alloc); +	refcount_add(size, &sk->sk_wmem_alloc);  	if (newskb) {  		err = unix_scm_to_skb(&scm, skb, false); @@ -2304,10 +2283,7 @@ static int unix_stream_read_generic(struct unix_stream_read_state *state,  	 */  	mutex_lock(&u->iolock); -	if (flags & MSG_PEEK) -		skip = sk_peek_offset(sk, flags); -	else -		skip = 0; +	skip = max(sk_peek_offset(sk, flags), 0);  	do {  		int chunk; @@ -2324,7 +2300,6 @@ redo:  		last_len = last ? last->len : 0;  again:  		if (skb == NULL) { -			unix_sk(sk)->recursion_level = 0;  			if (copied >= target)  				goto unlock; @@ -2847,7 +2822,7 @@ static int unix_seq_show(struct seq_file *seq, void *v)  		seq_printf(seq, "%pK: %08X %08X %08X %04X %02X %5lu",  			s, -			atomic_read(&s->sk_refcnt), +			refcount_read(&s->sk_refcnt),  			0,  			s->sk_state == TCP_LISTEN ? __SO_ACCEPTCON : 0,  			s->sk_type, | 
