提交 26bad2c0 编写于 作者: M Matthias Kaehlcke 提交者: David S. Miller

[TIPC]: Convert tsock->sem in a mutex

The semaphore tsock->sem is used as mutex, convert it to the mutex API
Signed-off-by: NMatthias Kaehlcke <matthias@kaehlcke.net>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 c572872f
...@@ -43,7 +43,7 @@ ...@@ -43,7 +43,7 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/poll.h> #include <linux/poll.h>
#include <linux/fcntl.h> #include <linux/fcntl.h>
#include <asm/semaphore.h> #include <linux/mutex.h>
#include <asm/string.h> #include <asm/string.h>
#include <asm/atomic.h> #include <asm/atomic.h>
#include <net/sock.h> #include <net/sock.h>
...@@ -63,7 +63,7 @@ ...@@ -63,7 +63,7 @@
struct tipc_sock { struct tipc_sock {
struct sock sk; struct sock sk;
struct tipc_port *p; struct tipc_port *p;
struct semaphore sem; struct mutex lock;
}; };
#define tipc_sk(sk) ((struct tipc_sock*)sk) #define tipc_sk(sk) ((struct tipc_sock*)sk)
...@@ -217,7 +217,7 @@ static int tipc_create(struct net *net, struct socket *sock, int protocol) ...@@ -217,7 +217,7 @@ static int tipc_create(struct net *net, struct socket *sock, int protocol)
tsock->p = port; tsock->p = port;
port->usr_handle = tsock; port->usr_handle = tsock;
init_MUTEX(&tsock->sem); mutex_init(&tsock->lock);
dbg("sock_create: %x\n",tsock); dbg("sock_create: %x\n",tsock);
...@@ -253,9 +253,9 @@ static int release(struct socket *sock) ...@@ -253,9 +253,9 @@ static int release(struct socket *sock)
dbg("sock_delete: %x\n",tsock); dbg("sock_delete: %x\n",tsock);
if (!tsock) if (!tsock)
return 0; return 0;
down(&tsock->sem); mutex_lock(&tsock->lock);
if (!sock->sk) { if (!sock->sk) {
up(&tsock->sem); mutex_unlock(&tsock->lock);
return 0; return 0;
} }
...@@ -288,7 +288,7 @@ static int release(struct socket *sock) ...@@ -288,7 +288,7 @@ static int release(struct socket *sock)
atomic_dec(&tipc_queue_size); atomic_dec(&tipc_queue_size);
} }
up(&tsock->sem); mutex_unlock(&tsock->lock);
sock_put(sk); sock_put(sk);
...@@ -315,7 +315,7 @@ static int bind(struct socket *sock, struct sockaddr *uaddr, int uaddr_len) ...@@ -315,7 +315,7 @@ static int bind(struct socket *sock, struct sockaddr *uaddr, int uaddr_len)
struct sockaddr_tipc *addr = (struct sockaddr_tipc *)uaddr; struct sockaddr_tipc *addr = (struct sockaddr_tipc *)uaddr;
int res; int res;
if (down_interruptible(&tsock->sem)) if (mutex_lock_interruptible(&tsock->lock))
return -ERESTARTSYS; return -ERESTARTSYS;
if (unlikely(!uaddr_len)) { if (unlikely(!uaddr_len)) {
...@@ -346,7 +346,7 @@ static int bind(struct socket *sock, struct sockaddr *uaddr, int uaddr_len) ...@@ -346,7 +346,7 @@ static int bind(struct socket *sock, struct sockaddr *uaddr, int uaddr_len)
res = tipc_withdraw(tsock->p->ref, -addr->scope, res = tipc_withdraw(tsock->p->ref, -addr->scope,
&addr->addr.nameseq); &addr->addr.nameseq);
exit: exit:
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
...@@ -367,7 +367,7 @@ static int get_name(struct socket *sock, struct sockaddr *uaddr, ...@@ -367,7 +367,7 @@ static int get_name(struct socket *sock, struct sockaddr *uaddr,
struct sockaddr_tipc *addr = (struct sockaddr_tipc *)uaddr; struct sockaddr_tipc *addr = (struct sockaddr_tipc *)uaddr;
u32 res; u32 res;
if (down_interruptible(&tsock->sem)) if (mutex_lock_interruptible(&tsock->lock))
return -ERESTARTSYS; return -ERESTARTSYS;
*uaddr_len = sizeof(*addr); *uaddr_len = sizeof(*addr);
...@@ -380,7 +380,7 @@ static int get_name(struct socket *sock, struct sockaddr *uaddr, ...@@ -380,7 +380,7 @@ static int get_name(struct socket *sock, struct sockaddr *uaddr,
res = tipc_ownidentity(tsock->p->ref, &addr->addr.id); res = tipc_ownidentity(tsock->p->ref, &addr->addr.id);
addr->addr.name.domain = 0; addr->addr.name.domain = 0;
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
...@@ -477,7 +477,7 @@ static int send_msg(struct kiocb *iocb, struct socket *sock, ...@@ -477,7 +477,7 @@ static int send_msg(struct kiocb *iocb, struct socket *sock,
} }
} }
if (down_interruptible(&tsock->sem)) if (mutex_lock_interruptible(&tsock->lock))
return -ERESTARTSYS; return -ERESTARTSYS;
if (needs_conn) { if (needs_conn) {
...@@ -523,7 +523,7 @@ static int send_msg(struct kiocb *iocb, struct socket *sock, ...@@ -523,7 +523,7 @@ static int send_msg(struct kiocb *iocb, struct socket *sock,
} }
if (likely(res != -ELINKCONG)) { if (likely(res != -ELINKCONG)) {
exit: exit:
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
if (m->msg_flags & MSG_DONTWAIT) { if (m->msg_flags & MSG_DONTWAIT) {
...@@ -562,7 +562,7 @@ static int send_packet(struct kiocb *iocb, struct socket *sock, ...@@ -562,7 +562,7 @@ static int send_packet(struct kiocb *iocb, struct socket *sock,
if (unlikely(dest)) if (unlikely(dest))
return send_msg(iocb, sock, m, total_len); return send_msg(iocb, sock, m, total_len);
if (down_interruptible(&tsock->sem)) { if (mutex_lock_interruptible(&tsock->lock)) {
return -ERESTARTSYS; return -ERESTARTSYS;
} }
...@@ -578,7 +578,7 @@ static int send_packet(struct kiocb *iocb, struct socket *sock, ...@@ -578,7 +578,7 @@ static int send_packet(struct kiocb *iocb, struct socket *sock,
res = tipc_send(tsock->p->ref, m->msg_iovlen, m->msg_iov); res = tipc_send(tsock->p->ref, m->msg_iovlen, m->msg_iov);
if (likely(res != -ELINKCONG)) { if (likely(res != -ELINKCONG)) {
exit: exit:
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
if (m->msg_flags & MSG_DONTWAIT) { if (m->msg_flags & MSG_DONTWAIT) {
...@@ -846,7 +846,7 @@ static int recv_msg(struct kiocb *iocb, struct socket *sock, ...@@ -846,7 +846,7 @@ static int recv_msg(struct kiocb *iocb, struct socket *sock,
/* Look for a message in receive queue; wait if necessary */ /* Look for a message in receive queue; wait if necessary */
if (unlikely(down_interruptible(&tsock->sem))) if (unlikely(mutex_lock_interruptible(&tsock->lock)))
return -ERESTARTSYS; return -ERESTARTSYS;
restart: restart:
...@@ -930,7 +930,7 @@ static int recv_msg(struct kiocb *iocb, struct socket *sock, ...@@ -930,7 +930,7 @@ static int recv_msg(struct kiocb *iocb, struct socket *sock,
advance_queue(tsock); advance_queue(tsock);
} }
exit: exit:
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
...@@ -981,7 +981,7 @@ static int recv_stream(struct kiocb *iocb, struct socket *sock, ...@@ -981,7 +981,7 @@ static int recv_stream(struct kiocb *iocb, struct socket *sock,
/* Look for a message in receive queue; wait if necessary */ /* Look for a message in receive queue; wait if necessary */
if (unlikely(down_interruptible(&tsock->sem))) if (unlikely(mutex_lock_interruptible(&tsock->lock)))
return -ERESTARTSYS; return -ERESTARTSYS;
restart: restart:
...@@ -1077,7 +1077,7 @@ static int recv_stream(struct kiocb *iocb, struct socket *sock, ...@@ -1077,7 +1077,7 @@ static int recv_stream(struct kiocb *iocb, struct socket *sock,
goto restart; goto restart;
exit: exit:
up(&tsock->sem); mutex_unlock(&tsock->lock);
return sz_copied ? sz_copied : res; return sz_copied ? sz_copied : res;
} }
...@@ -1293,7 +1293,7 @@ static int connect(struct socket *sock, struct sockaddr *dest, int destlen, ...@@ -1293,7 +1293,7 @@ static int connect(struct socket *sock, struct sockaddr *dest, int destlen,
return res; return res;
} }
if (down_interruptible(&tsock->sem)) if (mutex_lock_interruptible(&tsock->lock))
return -ERESTARTSYS; return -ERESTARTSYS;
/* Wait for destination's 'ACK' response */ /* Wait for destination's 'ACK' response */
...@@ -1317,7 +1317,7 @@ static int connect(struct socket *sock, struct sockaddr *dest, int destlen, ...@@ -1317,7 +1317,7 @@ static int connect(struct socket *sock, struct sockaddr *dest, int destlen,
sock->state = SS_DISCONNECTING; sock->state = SS_DISCONNECTING;
} }
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
...@@ -1365,7 +1365,7 @@ static int accept(struct socket *sock, struct socket *newsock, int flags) ...@@ -1365,7 +1365,7 @@ static int accept(struct socket *sock, struct socket *newsock, int flags)
(flags & O_NONBLOCK))) (flags & O_NONBLOCK)))
return -EWOULDBLOCK; return -EWOULDBLOCK;
if (down_interruptible(&tsock->sem)) if (mutex_lock_interruptible(&tsock->lock))
return -ERESTARTSYS; return -ERESTARTSYS;
if (wait_event_interruptible(*sock->sk->sk_sleep, if (wait_event_interruptible(*sock->sk->sk_sleep,
...@@ -1412,7 +1412,7 @@ static int accept(struct socket *sock, struct socket *newsock, int flags) ...@@ -1412,7 +1412,7 @@ static int accept(struct socket *sock, struct socket *newsock, int flags)
} }
} }
exit: exit:
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
...@@ -1434,7 +1434,7 @@ static int shutdown(struct socket *sock, int how) ...@@ -1434,7 +1434,7 @@ static int shutdown(struct socket *sock, int how)
/* Could return -EINVAL for an invalid "how", but why bother? */ /* Could return -EINVAL for an invalid "how", but why bother? */
if (down_interruptible(&tsock->sem)) if (mutex_lock_interruptible(&tsock->lock))
return -ERESTARTSYS; return -ERESTARTSYS;
sock_lock(tsock); sock_lock(tsock);
...@@ -1484,7 +1484,7 @@ static int shutdown(struct socket *sock, int how) ...@@ -1484,7 +1484,7 @@ static int shutdown(struct socket *sock, int how)
sock_unlock(tsock); sock_unlock(tsock);
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
...@@ -1518,7 +1518,7 @@ static int setsockopt(struct socket *sock, ...@@ -1518,7 +1518,7 @@ static int setsockopt(struct socket *sock,
if ((res = get_user(value, (u32 __user *)ov))) if ((res = get_user(value, (u32 __user *)ov)))
return res; return res;
if (down_interruptible(&tsock->sem)) if (mutex_lock_interruptible(&tsock->lock))
return -ERESTARTSYS; return -ERESTARTSYS;
switch (opt) { switch (opt) {
...@@ -1541,7 +1541,7 @@ static int setsockopt(struct socket *sock, ...@@ -1541,7 +1541,7 @@ static int setsockopt(struct socket *sock,
res = -EINVAL; res = -EINVAL;
} }
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
...@@ -1574,7 +1574,7 @@ static int getsockopt(struct socket *sock, ...@@ -1574,7 +1574,7 @@ static int getsockopt(struct socket *sock,
if ((res = get_user(len, ol))) if ((res = get_user(len, ol)))
return res; return res;
if (down_interruptible(&tsock->sem)) if (mutex_lock_interruptible(&tsock->lock))
return -ERESTARTSYS; return -ERESTARTSYS;
switch (opt) { switch (opt) {
...@@ -1607,7 +1607,7 @@ static int getsockopt(struct socket *sock, ...@@ -1607,7 +1607,7 @@ static int getsockopt(struct socket *sock,
res = put_user(sizeof(value), ol); res = put_user(sizeof(value), ol);
} }
up(&tsock->sem); mutex_unlock(&tsock->lock);
return res; return res;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册