aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2012-08-27 03:11:34 -0400
committerAl Viro <viro@zeniv.linux.org.uk>2012-09-26 21:10:09 -0400
commit515e0d6634086d61ae846f0e8785b6f0220f3422 (patch)
treeb099c7ec3b4c075851a70e56c4683e412ca3492e
parentbdbf69437a5ae6f820a6d3aa8c6e3c3ce7e6e05f (diff)
switch mqueue syscalls to fget_light()
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r--ipc/mqueue.c26
1 files changed, 14 insertions, 12 deletions
diff --git a/ipc/mqueue.c b/ipc/mqueue.c
index 9a08acc9e649..5db1b69500fd 100644
--- a/ipc/mqueue.c
+++ b/ipc/mqueue.c
@@ -953,7 +953,7 @@ SYSCALL_DEFINE5(mq_timedsend, mqd_t, mqdes, const char __user *, u_msg_ptr,
953 ktime_t expires, *timeout = NULL; 953 ktime_t expires, *timeout = NULL;
954 struct timespec ts; 954 struct timespec ts;
955 struct posix_msg_tree_node *new_leaf = NULL; 955 struct posix_msg_tree_node *new_leaf = NULL;
956 int ret = 0; 956 int ret = 0, fput_needed;
957 957
958 if (u_abs_timeout) { 958 if (u_abs_timeout) {
959 int res = prepare_timeout(u_abs_timeout, &expires, &ts); 959 int res = prepare_timeout(u_abs_timeout, &expires, &ts);
@@ -967,7 +967,7 @@ SYSCALL_DEFINE5(mq_timedsend, mqd_t, mqdes, const char __user *, u_msg_ptr,
967 967
968 audit_mq_sendrecv(mqdes, msg_len, msg_prio, timeout ? &ts : NULL); 968 audit_mq_sendrecv(mqdes, msg_len, msg_prio, timeout ? &ts : NULL);
969 969
970 filp = fget(mqdes); 970 filp = fget_light(mqdes, &fput_needed);
971 if (unlikely(!filp)) { 971 if (unlikely(!filp)) {
972 ret = -EBADF; 972 ret = -EBADF;
973 goto out; 973 goto out;
@@ -1056,7 +1056,7 @@ out_free:
1056 if (ret) 1056 if (ret)
1057 free_msg(msg_ptr); 1057 free_msg(msg_ptr);
1058out_fput: 1058out_fput:
1059 fput(filp); 1059 fput_light(filp, fput_needed);
1060out: 1060out:
1061 return ret; 1061 return ret;
1062} 1062}
@@ -1074,6 +1074,7 @@ SYSCALL_DEFINE5(mq_timedreceive, mqd_t, mqdes, char __user *, u_msg_ptr,
1074 ktime_t expires, *timeout = NULL; 1074 ktime_t expires, *timeout = NULL;
1075 struct timespec ts; 1075 struct timespec ts;
1076 struct posix_msg_tree_node *new_leaf = NULL; 1076 struct posix_msg_tree_node *new_leaf = NULL;
1077 int fput_needed;
1077 1078
1078 if (u_abs_timeout) { 1079 if (u_abs_timeout) {
1079 int res = prepare_timeout(u_abs_timeout, &expires, &ts); 1080 int res = prepare_timeout(u_abs_timeout, &expires, &ts);
@@ -1084,7 +1085,7 @@ SYSCALL_DEFINE5(mq_timedreceive, mqd_t, mqdes, char __user *, u_msg_ptr,
1084 1085
1085 audit_mq_sendrecv(mqdes, msg_len, 0, timeout ? &ts : NULL); 1086 audit_mq_sendrecv(mqdes, msg_len, 0, timeout ? &ts : NULL);
1086 1087
1087 filp = fget(mqdes); 1088 filp = fget_light(mqdes, &fput_needed);
1088 if (unlikely(!filp)) { 1089 if (unlikely(!filp)) {
1089 ret = -EBADF; 1090 ret = -EBADF;
1090 goto out; 1091 goto out;
@@ -1160,7 +1161,7 @@ SYSCALL_DEFINE5(mq_timedreceive, mqd_t, mqdes, char __user *, u_msg_ptr,
1160 free_msg(msg_ptr); 1161 free_msg(msg_ptr);
1161 } 1162 }
1162out_fput: 1163out_fput:
1163 fput(filp); 1164 fput_light(filp, fput_needed);
1164out: 1165out:
1165 return ret; 1166 return ret;
1166} 1167}
@@ -1173,7 +1174,7 @@ out:
1173SYSCALL_DEFINE2(mq_notify, mqd_t, mqdes, 1174SYSCALL_DEFINE2(mq_notify, mqd_t, mqdes,
1174 const struct sigevent __user *, u_notification) 1175 const struct sigevent __user *, u_notification)
1175{ 1176{
1176 int ret; 1177 int ret, fput_needed;
1177 struct file *filp; 1178 struct file *filp;
1178 struct sock *sock; 1179 struct sock *sock;
1179 struct inode *inode; 1180 struct inode *inode;
@@ -1220,13 +1221,13 @@ SYSCALL_DEFINE2(mq_notify, mqd_t, mqdes,
1220 skb_put(nc, NOTIFY_COOKIE_LEN); 1221 skb_put(nc, NOTIFY_COOKIE_LEN);
1221 /* and attach it to the socket */ 1222 /* and attach it to the socket */
1222retry: 1223retry:
1223 filp = fget(notification.sigev_signo); 1224 filp = fget_light(notification.sigev_signo, &fput_needed);
1224 if (!filp) { 1225 if (!filp) {
1225 ret = -EBADF; 1226 ret = -EBADF;
1226 goto out; 1227 goto out;
1227 } 1228 }
1228 sock = netlink_getsockbyfilp(filp); 1229 sock = netlink_getsockbyfilp(filp);
1229 fput(filp); 1230 fput_light(filp, fput_needed);
1230 if (IS_ERR(sock)) { 1231 if (IS_ERR(sock)) {
1231 ret = PTR_ERR(sock); 1232 ret = PTR_ERR(sock);
1232 sock = NULL; 1233 sock = NULL;
@@ -1245,7 +1246,7 @@ retry:
1245 } 1246 }
1246 } 1247 }
1247 1248
1248 filp = fget(mqdes); 1249 filp = fget_light(mqdes, &fput_needed);
1249 if (!filp) { 1250 if (!filp) {
1250 ret = -EBADF; 1251 ret = -EBADF;
1251 goto out; 1252 goto out;
@@ -1292,7 +1293,7 @@ retry:
1292 } 1293 }
1293 spin_unlock(&info->lock); 1294 spin_unlock(&info->lock);
1294out_fput: 1295out_fput:
1295 fput(filp); 1296 fput_light(filp, fput_needed);
1296out: 1297out:
1297 if (sock) { 1298 if (sock) {
1298 netlink_detachskb(sock, nc); 1299 netlink_detachskb(sock, nc);
@@ -1308,6 +1309,7 @@ SYSCALL_DEFINE3(mq_getsetattr, mqd_t, mqdes,
1308{ 1309{
1309 int ret; 1310 int ret;
1310 struct mq_attr mqstat, omqstat; 1311 struct mq_attr mqstat, omqstat;
1312 int fput_needed;
1311 struct file *filp; 1313 struct file *filp;
1312 struct inode *inode; 1314 struct inode *inode;
1313 struct mqueue_inode_info *info; 1315 struct mqueue_inode_info *info;
@@ -1319,7 +1321,7 @@ SYSCALL_DEFINE3(mq_getsetattr, mqd_t, mqdes,
1319 return -EINVAL; 1321 return -EINVAL;
1320 } 1322 }
1321 1323
1322 filp = fget(mqdes); 1324 filp = fget_light(mqdes, &fput_needed);
1323 if (!filp) { 1325 if (!filp) {
1324 ret = -EBADF; 1326 ret = -EBADF;
1325 goto out; 1327 goto out;
@@ -1356,7 +1358,7 @@ SYSCALL_DEFINE3(mq_getsetattr, mqd_t, mqdes,
1356 ret = -EFAULT; 1358 ret = -EFAULT;
1357 1359
1358out_fput: 1360out_fput:
1359 fput(filp); 1361 fput_light(filp, fput_needed);
1360out: 1362out:
1361 return ret; 1363 return ret;
1362} 1364}