diff options
Diffstat (limited to 'net/unix/af_unix.c')
| -rw-r--r-- | net/unix/af_unix.c | 12 | 
1 files changed, 6 insertions, 6 deletions
| diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c index 27ebda4cd9b9..900bad88fbd2 100644 --- a/net/unix/af_unix.c +++ b/net/unix/af_unix.c @@ -1626,10 +1626,12 @@ restart:  	/* The way is open! Fastly set all the necessary fields... */  	sock_hold(sk); -	unix_peer(newsk)	= sk; -	newsk->sk_state		= TCP_ESTABLISHED; -	newsk->sk_type		= sk->sk_type; +	unix_peer(newsk) = sk; +	newsk->sk_state = TCP_ESTABLISHED; +	newsk->sk_type = sk->sk_type; +	newsk->sk_scm_recv_flags = other->sk_scm_recv_flags;  	init_peercred(newsk); +  	newu = unix_sk(newsk);  	newu->listener = other;  	RCU_INIT_POINTER(newsk->sk_wq, &newu->peer_wq); @@ -1746,7 +1748,6 @@ static int unix_accept(struct socket *sock, struct socket *newsock,  	unix_state_lock(tsk);  	unix_update_edges(unix_sk(tsk));  	newsock->state = SS_CONNECTED; -	tsk->sk_scm_recv_flags = READ_ONCE(sk->sk_scm_recv_flags);  	sock_graft(tsk, newsock);  	unix_state_unlock(tsk);  	return 0; @@ -1878,8 +1879,7 @@ static void unix_maybe_add_creds(struct sk_buff *skb, const struct sock *sk,  	if (UNIXCB(skb).pid)  		return; -	if (unix_may_passcred(sk) || -	    !other->sk_socket || unix_may_passcred(other)) { +	if (unix_may_passcred(sk) || unix_may_passcred(other)) {  		UNIXCB(skb).pid = get_pid(task_tgid(current));  		current_uid_gid(&UNIXCB(skb).uid, &UNIXCB(skb).gid);  	} | 
