diff options
Diffstat (limited to 'net/unix/af_unix.c')
| -rw-r--r-- | net/unix/af_unix.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c index 86de99ad2976..01625ccc3ae6 100644 --- a/net/unix/af_unix.c +++ b/net/unix/af_unix.c | |||
| @@ -1246,6 +1246,15 @@ static int unix_socketpair(struct socket *socka, struct socket *sockb) | |||
| 1246 | return 0; | 1246 | return 0; |
| 1247 | } | 1247 | } |
| 1248 | 1248 | ||
| 1249 | static void unix_sock_inherit_flags(const struct socket *old, | ||
| 1250 | struct socket *new) | ||
| 1251 | { | ||
| 1252 | if (test_bit(SOCK_PASSCRED, &old->flags)) | ||
| 1253 | set_bit(SOCK_PASSCRED, &new->flags); | ||
| 1254 | if (test_bit(SOCK_PASSSEC, &old->flags)) | ||
| 1255 | set_bit(SOCK_PASSSEC, &new->flags); | ||
| 1256 | } | ||
| 1257 | |||
| 1249 | static int unix_accept(struct socket *sock, struct socket *newsock, int flags) | 1258 | static int unix_accept(struct socket *sock, struct socket *newsock, int flags) |
| 1250 | { | 1259 | { |
| 1251 | struct sock *sk = sock->sk; | 1260 | struct sock *sk = sock->sk; |
| @@ -1280,6 +1289,7 @@ static int unix_accept(struct socket *sock, struct socket *newsock, int flags) | |||
| 1280 | /* attach accepted sock to socket */ | 1289 | /* attach accepted sock to socket */ |
| 1281 | unix_state_lock(tsk); | 1290 | unix_state_lock(tsk); |
| 1282 | newsock->state = SS_CONNECTED; | 1291 | newsock->state = SS_CONNECTED; |
| 1292 | unix_sock_inherit_flags(sock, newsock); | ||
| 1283 | sock_graft(tsk, newsock); | 1293 | sock_graft(tsk, newsock); |
| 1284 | unix_state_unlock(tsk); | 1294 | unix_state_unlock(tsk); |
| 1285 | return 0; | 1295 | return 0; |
| @@ -1744,7 +1754,6 @@ static void unix_copy_addr(struct msghdr *msg, struct sock *sk) | |||
| 1744 | { | 1754 | { |
| 1745 | struct unix_sock *u = unix_sk(sk); | 1755 | struct unix_sock *u = unix_sk(sk); |
| 1746 | 1756 | ||
| 1747 | msg->msg_namelen = 0; | ||
| 1748 | if (u->addr) { | 1757 | if (u->addr) { |
| 1749 | msg->msg_namelen = u->addr->len; | 1758 | msg->msg_namelen = u->addr->len; |
| 1750 | memcpy(msg->msg_name, u->addr->name, u->addr->len); | 1759 | memcpy(msg->msg_name, u->addr->name, u->addr->len); |
| @@ -1768,8 +1777,6 @@ static int unix_dgram_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
| 1768 | if (flags&MSG_OOB) | 1777 | if (flags&MSG_OOB) |
| 1769 | goto out; | 1778 | goto out; |
| 1770 | 1779 | ||
| 1771 | msg->msg_namelen = 0; | ||
| 1772 | |||
| 1773 | err = mutex_lock_interruptible(&u->readlock); | 1780 | err = mutex_lock_interruptible(&u->readlock); |
| 1774 | if (err) { | 1781 | if (err) { |
| 1775 | err = sock_intr_errno(sock_rcvtimeo(sk, noblock)); | 1782 | err = sock_intr_errno(sock_rcvtimeo(sk, noblock)); |
| @@ -1914,8 +1921,6 @@ static int unix_stream_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
| 1914 | target = sock_rcvlowat(sk, flags&MSG_WAITALL, size); | 1921 | target = sock_rcvlowat(sk, flags&MSG_WAITALL, size); |
| 1915 | timeo = sock_rcvtimeo(sk, flags&MSG_DONTWAIT); | 1922 | timeo = sock_rcvtimeo(sk, flags&MSG_DONTWAIT); |
| 1916 | 1923 | ||
| 1917 | msg->msg_namelen = 0; | ||
| 1918 | |||
| 1919 | /* Lock the socket to prevent queue disordering | 1924 | /* Lock the socket to prevent queue disordering |
| 1920 | * while sleeps in memcpy_tomsg | 1925 | * while sleeps in memcpy_tomsg |
| 1921 | */ | 1926 | */ |
