X-Git-Url: http://git.monstr.eu/?a=blobdiff_plain;f=net%2Fsocket.c;h=33e8b6c4e1d38201893fc087052a395415baab49;hb=be695ee29e8fc0af266d9f1882868c47da01a790;hp=9a240b45bdf39018747d282b5919a99b085f9ecc;hpb=e20a9b92ddbfe662807622dbb28e1fbb6e0011aa;p=linux-2.6-microblaze.git diff --git a/net/socket.c b/net/socket.c index 9a240b45bdf3..33e8b6c4e1d3 100644 --- a/net/socket.c +++ b/net/socket.c @@ -2175,6 +2175,17 @@ SYSCALL_DEFINE5(getsockopt, int, fd, int, level, int, optname, * Shutdown a socket. */ +int __sys_shutdown_sock(struct socket *sock, int how) +{ + int err; + + err = security_socket_shutdown(sock, how); + if (!err) + err = sock->ops->shutdown(sock, how); + + return err; +} + int __sys_shutdown(int fd, int how) { int err, fput_needed; @@ -2182,9 +2193,7 @@ int __sys_shutdown(int fd, int how) sock = sockfd_lookup_light(fd, &err, &fput_needed); if (sock != NULL) { - err = security_socket_shutdown(sock, how); - if (!err) - err = sock->ops->shutdown(sock, how); + err = __sys_shutdown_sock(sock, how); fput_light(sock->file, fput_needed); } return err;