diff options
Diffstat (limited to 'net/unix/af_unix.c')
-rw-r--r-- | net/unix/af_unix.c | 73 |
1 files changed, 36 insertions, 37 deletions
diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c index dc504d308ec0..0b80634b2b72 100644 --- a/net/unix/af_unix.c +++ b/net/unix/af_unix.c | |||
@@ -211,7 +211,7 @@ static int unix_mkname(struct sockaddr_un * sunaddr, int len, unsigned *hashp) | |||
211 | * we are guaranteed that it is a valid memory location in our | 211 | * we are guaranteed that it is a valid memory location in our |
212 | * kernel address buffer. | 212 | * kernel address buffer. |
213 | */ | 213 | */ |
214 | ((char *)sunaddr)[len]=0; | 214 | ((char *)sunaddr)[len] = 0; |
215 | len = strlen(sunaddr->sun_path)+1+sizeof(short); | 215 | len = strlen(sunaddr->sun_path)+1+sizeof(short); |
216 | return len; | 216 | return len; |
217 | } | 217 | } |
@@ -392,9 +392,9 @@ static int unix_release_sock (struct sock *sk, int embrion) | |||
392 | 392 | ||
393 | wake_up_interruptible_all(&u->peer_wait); | 393 | wake_up_interruptible_all(&u->peer_wait); |
394 | 394 | ||
395 | skpair=unix_peer(sk); | 395 | skpair = unix_peer(sk); |
396 | 396 | ||
397 | if (skpair!=NULL) { | 397 | if (skpair != NULL) { |
398 | if (sk->sk_type == SOCK_STREAM || sk->sk_type == SOCK_SEQPACKET) { | 398 | if (sk->sk_type == SOCK_STREAM || sk->sk_type == SOCK_SEQPACKET) { |
399 | unix_state_lock(skpair); | 399 | unix_state_lock(skpair); |
400 | /* No more writes */ | 400 | /* No more writes */ |
@@ -414,7 +414,7 @@ static int unix_release_sock (struct sock *sk, int embrion) | |||
414 | /* Try to flush out this socket. Throw out buffers at least */ | 414 | /* Try to flush out this socket. Throw out buffers at least */ |
415 | 415 | ||
416 | while ((skb = skb_dequeue(&sk->sk_receive_queue)) != NULL) { | 416 | while ((skb = skb_dequeue(&sk->sk_receive_queue)) != NULL) { |
417 | if (state==TCP_LISTEN) | 417 | if (state == TCP_LISTEN) |
418 | unix_release_sock(skb->sk, 1); | 418 | unix_release_sock(skb->sk, 1); |
419 | /* passed fds are erased in the kfree_skb hook */ | 419 | /* passed fds are erased in the kfree_skb hook */ |
420 | kfree_skb(skb); | 420 | kfree_skb(skb); |
@@ -630,7 +630,7 @@ static int unix_create(struct net *net, struct socket *sock, int protocol) | |||
630 | * nothing uses it. | 630 | * nothing uses it. |
631 | */ | 631 | */ |
632 | case SOCK_RAW: | 632 | case SOCK_RAW: |
633 | sock->type=SOCK_DGRAM; | 633 | sock->type = SOCK_DGRAM; |
634 | case SOCK_DGRAM: | 634 | case SOCK_DGRAM: |
635 | sock->ops = &unix_dgram_ops; | 635 | sock->ops = &unix_dgram_ops; |
636 | break; | 636 | break; |
@@ -736,14 +736,14 @@ static struct sock *unix_find_other(struct net *net, | |||
736 | 736 | ||
737 | path_put(&path); | 737 | path_put(&path); |
738 | 738 | ||
739 | err=-EPROTOTYPE; | 739 | err = -EPROTOTYPE; |
740 | if (u->sk_type != type) { | 740 | if (u->sk_type != type) { |
741 | sock_put(u); | 741 | sock_put(u); |
742 | goto fail; | 742 | goto fail; |
743 | } | 743 | } |
744 | } else { | 744 | } else { |
745 | err = -ECONNREFUSED; | 745 | err = -ECONNREFUSED; |
746 | u=unix_find_socket_byname(net, sunname, len, type, hash); | 746 | u = unix_find_socket_byname(net, sunname, len, type, hash); |
747 | if (u) { | 747 | if (u) { |
748 | struct dentry *dentry; | 748 | struct dentry *dentry; |
749 | dentry = unix_sk(u)->dentry; | 749 | dentry = unix_sk(u)->dentry; |
@@ -757,7 +757,7 @@ static struct sock *unix_find_other(struct net *net, | |||
757 | put_fail: | 757 | put_fail: |
758 | path_put(&path); | 758 | path_put(&path); |
759 | fail: | 759 | fail: |
760 | *error=err; | 760 | *error = err; |
761 | return NULL; | 761 | return NULL; |
762 | } | 762 | } |
763 | 763 | ||
@@ -767,7 +767,7 @@ static int unix_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len) | |||
767 | struct sock *sk = sock->sk; | 767 | struct sock *sk = sock->sk; |
768 | struct net *net = sock_net(sk); | 768 | struct net *net = sock_net(sk); |
769 | struct unix_sock *u = unix_sk(sk); | 769 | struct unix_sock *u = unix_sk(sk); |
770 | struct sockaddr_un *sunaddr=(struct sockaddr_un *)uaddr; | 770 | struct sockaddr_un *sunaddr = (struct sockaddr_un *)uaddr; |
771 | struct dentry * dentry = NULL; | 771 | struct dentry * dentry = NULL; |
772 | struct nameidata nd; | 772 | struct nameidata nd; |
773 | int err; | 773 | int err; |
@@ -779,7 +779,7 @@ static int unix_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len) | |||
779 | if (sunaddr->sun_family != AF_UNIX) | 779 | if (sunaddr->sun_family != AF_UNIX) |
780 | goto out; | 780 | goto out; |
781 | 781 | ||
782 | if (addr_len==sizeof(short)) { | 782 | if (addr_len == sizeof(short)) { |
783 | err = unix_autobind(sock); | 783 | err = unix_autobind(sock); |
784 | goto out; | 784 | goto out; |
785 | } | 785 | } |
@@ -875,8 +875,8 @@ out_mknod_unlock: | |||
875 | mutex_unlock(&nd.path.dentry->d_inode->i_mutex); | 875 | mutex_unlock(&nd.path.dentry->d_inode->i_mutex); |
876 | path_put(&nd.path); | 876 | path_put(&nd.path); |
877 | out_mknod_parent: | 877 | out_mknod_parent: |
878 | if (err==-EEXIST) | 878 | if (err == -EEXIST) |
879 | err=-EADDRINUSE; | 879 | err = -EADDRINUSE; |
880 | unix_release_addr(addr); | 880 | unix_release_addr(addr); |
881 | goto out_up; | 881 | goto out_up; |
882 | } | 882 | } |
@@ -911,7 +911,7 @@ static int unix_dgram_connect(struct socket *sock, struct sockaddr *addr, | |||
911 | { | 911 | { |
912 | struct sock *sk = sock->sk; | 912 | struct sock *sk = sock->sk; |
913 | struct net *net = sock_net(sk); | 913 | struct net *net = sock_net(sk); |
914 | struct sockaddr_un *sunaddr=(struct sockaddr_un*)addr; | 914 | struct sockaddr_un *sunaddr = (struct sockaddr_un *)addr; |
915 | struct sock *other; | 915 | struct sock *other; |
916 | unsigned hash; | 916 | unsigned hash; |
917 | int err; | 917 | int err; |
@@ -927,7 +927,7 @@ static int unix_dgram_connect(struct socket *sock, struct sockaddr *addr, | |||
927 | goto out; | 927 | goto out; |
928 | 928 | ||
929 | restart: | 929 | restart: |
930 | other=unix_find_other(net, sunaddr, alen, sock->type, hash, &err); | 930 | other = unix_find_other(net, sunaddr, alen, sock->type, hash, &err); |
931 | if (!other) | 931 | if (!other) |
932 | goto out; | 932 | goto out; |
933 | 933 | ||
@@ -961,14 +961,14 @@ restart: | |||
961 | */ | 961 | */ |
962 | if (unix_peer(sk)) { | 962 | if (unix_peer(sk)) { |
963 | struct sock *old_peer = unix_peer(sk); | 963 | struct sock *old_peer = unix_peer(sk); |
964 | unix_peer(sk)=other; | 964 | unix_peer(sk) = other; |
965 | unix_state_double_unlock(sk, other); | 965 | unix_state_double_unlock(sk, other); |
966 | 966 | ||
967 | if (other != old_peer) | 967 | if (other != old_peer) |
968 | unix_dgram_disconnected(sk, old_peer); | 968 | unix_dgram_disconnected(sk, old_peer); |
969 | sock_put(old_peer); | 969 | sock_put(old_peer); |
970 | } else { | 970 | } else { |
971 | unix_peer(sk)=other; | 971 | unix_peer(sk) = other; |
972 | unix_state_double_unlock(sk, other); | 972 | unix_state_double_unlock(sk, other); |
973 | } | 973 | } |
974 | return 0; | 974 | return 0; |
@@ -1004,7 +1004,7 @@ static long unix_wait_for_peer(struct sock *other, long timeo) | |||
1004 | static int unix_stream_connect(struct socket *sock, struct sockaddr *uaddr, | 1004 | static int unix_stream_connect(struct socket *sock, struct sockaddr *uaddr, |
1005 | int addr_len, int flags) | 1005 | int addr_len, int flags) |
1006 | { | 1006 | { |
1007 | struct sockaddr_un *sunaddr=(struct sockaddr_un *)uaddr; | 1007 | struct sockaddr_un *sunaddr = (struct sockaddr_un *)uaddr; |
1008 | struct sock *sk = sock->sk; | 1008 | struct sock *sk = sock->sk; |
1009 | struct net *net = sock_net(sk); | 1009 | struct net *net = sock_net(sk); |
1010 | struct unix_sock *u = unix_sk(sk), *newu, *otheru; | 1010 | struct unix_sock *u = unix_sk(sk), *newu, *otheru; |
@@ -1179,13 +1179,13 @@ out: | |||
1179 | 1179 | ||
1180 | static int unix_socketpair(struct socket *socka, struct socket *sockb) | 1180 | static int unix_socketpair(struct socket *socka, struct socket *sockb) |
1181 | { | 1181 | { |
1182 | struct sock *ska=socka->sk, *skb = sockb->sk; | 1182 | struct sock *ska = socka->sk, *skb = sockb->sk; |
1183 | 1183 | ||
1184 | /* Join our sockets back to back */ | 1184 | /* Join our sockets back to back */ |
1185 | sock_hold(ska); | 1185 | sock_hold(ska); |
1186 | sock_hold(skb); | 1186 | sock_hold(skb); |
1187 | unix_peer(ska)=skb; | 1187 | unix_peer(ska) = skb; |
1188 | unix_peer(skb)=ska; | 1188 | unix_peer(skb) = ska; |
1189 | ska->sk_peercred.pid = skb->sk_peercred.pid = task_tgid_vnr(current); | 1189 | ska->sk_peercred.pid = skb->sk_peercred.pid = task_tgid_vnr(current); |
1190 | ska->sk_peercred.uid = skb->sk_peercred.uid = current->euid; | 1190 | ska->sk_peercred.uid = skb->sk_peercred.uid = current->euid; |
1191 | ska->sk_peercred.gid = skb->sk_peercred.gid = current->egid; | 1191 | ska->sk_peercred.gid = skb->sk_peercred.gid = current->egid; |
@@ -1246,7 +1246,7 @@ static int unix_getname(struct socket *sock, struct sockaddr *uaddr, int *uaddr_ | |||
1246 | { | 1246 | { |
1247 | struct sock *sk = sock->sk; | 1247 | struct sock *sk = sock->sk; |
1248 | struct unix_sock *u; | 1248 | struct unix_sock *u; |
1249 | struct sockaddr_un *sunaddr=(struct sockaddr_un *)uaddr; | 1249 | struct sockaddr_un *sunaddr = (struct sockaddr_un *)uaddr; |
1250 | int err = 0; | 1250 | int err = 0; |
1251 | 1251 | ||
1252 | if (peer) { | 1252 | if (peer) { |
@@ -1323,7 +1323,7 @@ static int unix_dgram_sendmsg(struct kiocb *kiocb, struct socket *sock, | |||
1323 | struct sock *sk = sock->sk; | 1323 | struct sock *sk = sock->sk; |
1324 | struct net *net = sock_net(sk); | 1324 | struct net *net = sock_net(sk); |
1325 | struct unix_sock *u = unix_sk(sk); | 1325 | struct unix_sock *u = unix_sk(sk); |
1326 | struct sockaddr_un *sunaddr=msg->msg_name; | 1326 | struct sockaddr_un *sunaddr = msg->msg_name; |
1327 | struct sock *other = NULL; | 1327 | struct sock *other = NULL; |
1328 | int namelen = 0; /* fake GCC */ | 1328 | int namelen = 0; /* fake GCC */ |
1329 | int err; | 1329 | int err; |
@@ -1364,7 +1364,7 @@ static int unix_dgram_sendmsg(struct kiocb *kiocb, struct socket *sock, | |||
1364 | goto out; | 1364 | goto out; |
1365 | 1365 | ||
1366 | skb = sock_alloc_send_skb(sk, len, msg->msg_flags&MSG_DONTWAIT, &err); | 1366 | skb = sock_alloc_send_skb(sk, len, msg->msg_flags&MSG_DONTWAIT, &err); |
1367 | if (skb==NULL) | 1367 | if (skb == NULL) |
1368 | goto out; | 1368 | goto out; |
1369 | 1369 | ||
1370 | memcpy(UNIXCREDS(skb), &siocb->scm->creds, sizeof(struct ucred)); | 1370 | memcpy(UNIXCREDS(skb), &siocb->scm->creds, sizeof(struct ucred)); |
@@ -1387,7 +1387,7 @@ restart: | |||
1387 | 1387 | ||
1388 | other = unix_find_other(net, sunaddr, namelen, sk->sk_type, | 1388 | other = unix_find_other(net, sunaddr, namelen, sk->sk_type, |
1389 | hash, &err); | 1389 | hash, &err); |
1390 | if (other==NULL) | 1390 | if (other == NULL) |
1391 | goto out_free; | 1391 | goto out_free; |
1392 | } | 1392 | } |
1393 | 1393 | ||
@@ -1407,7 +1407,7 @@ restart: | |||
1407 | err = 0; | 1407 | err = 0; |
1408 | unix_state_lock(sk); | 1408 | unix_state_lock(sk); |
1409 | if (unix_peer(sk) == other) { | 1409 | if (unix_peer(sk) == other) { |
1410 | unix_peer(sk)=NULL; | 1410 | unix_peer(sk) = NULL; |
1411 | unix_state_unlock(sk); | 1411 | unix_state_unlock(sk); |
1412 | 1412 | ||
1413 | unix_dgram_disconnected(sk, other); | 1413 | unix_dgram_disconnected(sk, other); |
@@ -1473,10 +1473,10 @@ static int unix_stream_sendmsg(struct kiocb *kiocb, struct socket *sock, | |||
1473 | struct sock_iocb *siocb = kiocb_to_siocb(kiocb); | 1473 | struct sock_iocb *siocb = kiocb_to_siocb(kiocb); |
1474 | struct sock *sk = sock->sk; | 1474 | struct sock *sk = sock->sk; |
1475 | struct sock *other = NULL; | 1475 | struct sock *other = NULL; |
1476 | struct sockaddr_un *sunaddr=msg->msg_name; | 1476 | struct sockaddr_un *sunaddr = msg->msg_name; |
1477 | int err,size; | 1477 | int err,size; |
1478 | struct sk_buff *skb; | 1478 | struct sk_buff *skb; |
1479 | int sent=0; | 1479 | int sent = 0; |
1480 | struct scm_cookie tmp_scm; | 1480 | struct scm_cookie tmp_scm; |
1481 | 1481 | ||
1482 | if (NULL == siocb->scm) | 1482 | if (NULL == siocb->scm) |
@@ -1523,9 +1523,9 @@ static int unix_stream_sendmsg(struct kiocb *kiocb, struct socket *sock, | |||
1523 | * Grab a buffer | 1523 | * Grab a buffer |
1524 | */ | 1524 | */ |
1525 | 1525 | ||
1526 | skb=sock_alloc_send_skb(sk,size,msg->msg_flags&MSG_DONTWAIT, &err); | 1526 | skb = sock_alloc_send_skb(sk,size,msg->msg_flags&MSG_DONTWAIT, &err); |
1527 | 1527 | ||
1528 | if (skb==NULL) | 1528 | if (skb == NULL) |
1529 | goto out_err; | 1529 | goto out_err; |
1530 | 1530 | ||
1531 | /* | 1531 | /* |
@@ -1555,7 +1555,7 @@ static int unix_stream_sendmsg(struct kiocb *kiocb, struct socket *sock, | |||
1555 | skb_queue_tail(&other->sk_receive_queue, skb); | 1555 | skb_queue_tail(&other->sk_receive_queue, skb); |
1556 | unix_state_unlock(other); | 1556 | unix_state_unlock(other); |
1557 | other->sk_data_ready(other, size); | 1557 | other->sk_data_ready(other, size); |
1558 | sent+=size; | 1558 | sent += size; |
1559 | } | 1559 | } |
1560 | 1560 | ||
1561 | scm_destroy(siocb->scm); | 1561 | scm_destroy(siocb->scm); |
@@ -1734,7 +1734,7 @@ static int unix_stream_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
1734 | struct scm_cookie tmp_scm; | 1734 | struct scm_cookie tmp_scm; |
1735 | struct sock *sk = sock->sk; | 1735 | struct sock *sk = sock->sk; |
1736 | struct unix_sock *u = unix_sk(sk); | 1736 | struct unix_sock *u = unix_sk(sk); |
1737 | struct sockaddr_un *sunaddr=msg->msg_name; | 1737 | struct sockaddr_un *sunaddr = msg->msg_name; |
1738 | int copied = 0; | 1738 | int copied = 0; |
1739 | int check_creds = 0; | 1739 | int check_creds = 0; |
1740 | int target; | 1740 | int target; |
@@ -1772,7 +1772,7 @@ static int unix_stream_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
1772 | 1772 | ||
1773 | unix_state_lock(sk); | 1773 | unix_state_lock(sk); |
1774 | skb = skb_dequeue(&sk->sk_receive_queue); | 1774 | skb = skb_dequeue(&sk->sk_receive_queue); |
1775 | if (skb==NULL) | 1775 | if (skb == NULL) |
1776 | { | 1776 | { |
1777 | if (copied >= target) | 1777 | if (copied >= target) |
1778 | goto unlock; | 1778 | goto unlock; |
@@ -1884,7 +1884,7 @@ static int unix_shutdown(struct socket *sock, int mode) | |||
1884 | if (mode) { | 1884 | if (mode) { |
1885 | unix_state_lock(sk); | 1885 | unix_state_lock(sk); |
1886 | sk->sk_shutdown |= mode; | 1886 | sk->sk_shutdown |= mode; |
1887 | other=unix_peer(sk); | 1887 | other = unix_peer(sk); |
1888 | if (other) | 1888 | if (other) |
1889 | sock_hold(other); | 1889 | sock_hold(other); |
1890 | unix_state_unlock(sk); | 1890 | unix_state_unlock(sk); |
@@ -1919,7 +1919,7 @@ static int unix_shutdown(struct socket *sock, int mode) | |||
1919 | static int unix_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg) | 1919 | static int unix_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg) |
1920 | { | 1920 | { |
1921 | struct sock *sk = sock->sk; | 1921 | struct sock *sk = sock->sk; |
1922 | long amount=0; | 1922 | long amount = 0; |
1923 | int err; | 1923 | int err; |
1924 | 1924 | ||
1925 | switch(cmd) | 1925 | switch(cmd) |
@@ -1945,7 +1945,7 @@ static int unix_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg) | |||
1945 | } else { | 1945 | } else { |
1946 | skb = skb_peek(&sk->sk_receive_queue); | 1946 | skb = skb_peek(&sk->sk_receive_queue); |
1947 | if (skb) | 1947 | if (skb) |
1948 | amount=skb->len; | 1948 | amount = skb->len; |
1949 | } | 1949 | } |
1950 | spin_unlock(&sk->sk_receive_queue.lock); | 1950 | spin_unlock(&sk->sk_receive_queue.lock); |
1951 | err = put_user(amount, (int __user *)arg); | 1951 | err = put_user(amount, (int __user *)arg); |
@@ -2077,6 +2077,7 @@ struct unix_iter_state { | |||
2077 | struct seq_net_private p; | 2077 | struct seq_net_private p; |
2078 | int i; | 2078 | int i; |
2079 | }; | 2079 | }; |
2080 | |||
2080 | static struct sock *unix_seq_idx(struct seq_file *seq, loff_t pos) | 2081 | static struct sock *unix_seq_idx(struct seq_file *seq, loff_t pos) |
2081 | { | 2082 | { |
2082 | struct unix_iter_state *iter = seq->private; | 2083 | struct unix_iter_state *iter = seq->private; |
@@ -2093,7 +2094,6 @@ static struct sock *unix_seq_idx(struct seq_file *seq, loff_t pos) | |||
2093 | return NULL; | 2094 | return NULL; |
2094 | } | 2095 | } |
2095 | 2096 | ||
2096 | |||
2097 | static void *unix_seq_start(struct seq_file *seq, loff_t *pos) | 2097 | static void *unix_seq_start(struct seq_file *seq, loff_t *pos) |
2098 | __acquires(unix_table_lock) | 2098 | __acquires(unix_table_lock) |
2099 | { | 2099 | { |
@@ -2173,7 +2173,6 @@ static const struct seq_operations unix_seq_ops = { | |||
2173 | .show = unix_seq_show, | 2173 | .show = unix_seq_show, |
2174 | }; | 2174 | }; |
2175 | 2175 | ||
2176 | |||
2177 | static int unix_seq_open(struct inode *inode, struct file *file) | 2176 | static int unix_seq_open(struct inode *inode, struct file *file) |
2178 | { | 2177 | { |
2179 | return seq_open_net(inode, file, &unix_seq_ops, | 2178 | return seq_open_net(inode, file, &unix_seq_ops, |