Commit 8651d5c0 authored by Paul Moore's avatar Paul Moore Committed by James Morris

lsm: Remove the socket_post_accept() hook

The socket_post_accept() hook is not currently used by any in-tree modules
and its existence continues to cause problems by confusing people about
what can be safely accomplished using this hook.  If a legitimate need for
this hook arises in the future it can always be reintroduced.
Signed-off-by: default avatarPaul Moore <paul.moore@hp.com>
Signed-off-by: default avatarJames Morris <jmorris@namei.org>
parent 58bfbb51
...@@ -880,11 +880,6 @@ static inline void security_free_mnt_opts(struct security_mnt_opts *opts) ...@@ -880,11 +880,6 @@ static inline void security_free_mnt_opts(struct security_mnt_opts *opts)
* @sock contains the listening socket structure. * @sock contains the listening socket structure.
* @newsock contains the newly created server socket for connection. * @newsock contains the newly created server socket for connection.
* Return 0 if permission is granted. * Return 0 if permission is granted.
* @socket_post_accept:
* This hook allows a security module to copy security
* information into the newly created socket's inode.
* @sock contains the listening socket structure.
* @newsock contains the newly created server socket for connection.
* @socket_sendmsg: * @socket_sendmsg:
* Check permission before transmitting a message to another socket. * Check permission before transmitting a message to another socket.
* @sock contains the socket structure. * @sock contains the socket structure.
...@@ -1554,8 +1549,6 @@ struct security_operations { ...@@ -1554,8 +1549,6 @@ struct security_operations {
struct sockaddr *address, int addrlen); struct sockaddr *address, int addrlen);
int (*socket_listen) (struct socket *sock, int backlog); int (*socket_listen) (struct socket *sock, int backlog);
int (*socket_accept) (struct socket *sock, struct socket *newsock); int (*socket_accept) (struct socket *sock, struct socket *newsock);
void (*socket_post_accept) (struct socket *sock,
struct socket *newsock);
int (*socket_sendmsg) (struct socket *sock, int (*socket_sendmsg) (struct socket *sock,
struct msghdr *msg, int size); struct msghdr *msg, int size);
int (*socket_recvmsg) (struct socket *sock, int (*socket_recvmsg) (struct socket *sock,
...@@ -2537,7 +2530,6 @@ int security_socket_bind(struct socket *sock, struct sockaddr *address, int addr ...@@ -2537,7 +2530,6 @@ int security_socket_bind(struct socket *sock, struct sockaddr *address, int addr
int security_socket_connect(struct socket *sock, struct sockaddr *address, int addrlen); int security_socket_connect(struct socket *sock, struct sockaddr *address, int addrlen);
int security_socket_listen(struct socket *sock, int backlog); int security_socket_listen(struct socket *sock, int backlog);
int security_socket_accept(struct socket *sock, struct socket *newsock); int security_socket_accept(struct socket *sock, struct socket *newsock);
void security_socket_post_accept(struct socket *sock, struct socket *newsock);
int security_socket_sendmsg(struct socket *sock, struct msghdr *msg, int size); int security_socket_sendmsg(struct socket *sock, struct msghdr *msg, int size);
int security_socket_recvmsg(struct socket *sock, struct msghdr *msg, int security_socket_recvmsg(struct socket *sock, struct msghdr *msg,
int size, int flags); int size, int flags);
...@@ -2616,11 +2608,6 @@ static inline int security_socket_accept(struct socket *sock, ...@@ -2616,11 +2608,6 @@ static inline int security_socket_accept(struct socket *sock,
return 0; return 0;
} }
static inline void security_socket_post_accept(struct socket *sock,
struct socket *newsock)
{
}
static inline int security_socket_sendmsg(struct socket *sock, static inline int security_socket_sendmsg(struct socket *sock,
struct msghdr *msg, int size) struct msghdr *msg, int size)
{ {
......
...@@ -1536,8 +1536,6 @@ SYSCALL_DEFINE4(accept4, int, fd, struct sockaddr __user *, upeer_sockaddr, ...@@ -1536,8 +1536,6 @@ SYSCALL_DEFINE4(accept4, int, fd, struct sockaddr __user *, upeer_sockaddr,
fd_install(newfd, newfile); fd_install(newfd, newfile);
err = newfd; err = newfd;
security_socket_post_accept(sock, newsock);
out_put: out_put:
fput_light(sock->file, fput_needed); fput_light(sock->file, fput_needed);
out: out:
......
...@@ -620,10 +620,6 @@ static int cap_socket_accept(struct socket *sock, struct socket *newsock) ...@@ -620,10 +620,6 @@ static int cap_socket_accept(struct socket *sock, struct socket *newsock)
return 0; return 0;
} }
static void cap_socket_post_accept(struct socket *sock, struct socket *newsock)
{
}
static int cap_socket_sendmsg(struct socket *sock, struct msghdr *msg, int size) static int cap_socket_sendmsg(struct socket *sock, struct msghdr *msg, int size)
{ {
return 0; return 0;
...@@ -1014,7 +1010,6 @@ void security_fixup_ops(struct security_operations *ops) ...@@ -1014,7 +1010,6 @@ void security_fixup_ops(struct security_operations *ops)
set_to_cap_if_null(ops, socket_connect); set_to_cap_if_null(ops, socket_connect);
set_to_cap_if_null(ops, socket_listen); set_to_cap_if_null(ops, socket_listen);
set_to_cap_if_null(ops, socket_accept); set_to_cap_if_null(ops, socket_accept);
set_to_cap_if_null(ops, socket_post_accept);
set_to_cap_if_null(ops, socket_sendmsg); set_to_cap_if_null(ops, socket_sendmsg);
set_to_cap_if_null(ops, socket_recvmsg); set_to_cap_if_null(ops, socket_recvmsg);
set_to_cap_if_null(ops, socket_getsockname); set_to_cap_if_null(ops, socket_getsockname);
......
...@@ -1007,11 +1007,6 @@ int security_socket_accept(struct socket *sock, struct socket *newsock) ...@@ -1007,11 +1007,6 @@ int security_socket_accept(struct socket *sock, struct socket *newsock)
return security_ops->socket_accept(sock, newsock); return security_ops->socket_accept(sock, newsock);
} }
void security_socket_post_accept(struct socket *sock, struct socket *newsock)
{
security_ops->socket_post_accept(sock, newsock);
}
int security_socket_sendmsg(struct socket *sock, struct msghdr *msg, int size) int security_socket_sendmsg(struct socket *sock, struct msghdr *msg, int size)
{ {
return security_ops->socket_sendmsg(sock, msg, size); return security_ops->socket_sendmsg(sock, msg, size);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment