3.13.11.7 -stable review patch.  If anyone has any objections, please let me 
know.

------------------

From: Paul Moore <[email protected]>

commit 2873ead7e46694910ac49c3a8ee0f54956f96e0c upstream.

This reverts commit 4da6daf4d3df5a977e4623963f141a627fd2efce.

Unfortunately, the commit in question caused problems with Bluetooth
devices, specifically it caused them to get caught in the newly
created BUG_ON() check.  The AF_ALG problem still exists, but will be
addressed in a future patch.

Signed-off-by: Paul Moore <[email protected]>
Signed-off-by: Kamal Mostafa <[email protected]>
---
 include/linux/security.h |  5 +----
 security/selinux/hooks.c | 13 ++-----------
 2 files changed, 3 insertions(+), 15 deletions(-)

diff --git a/include/linux/security.h b/include/linux/security.h
index e42af21..5623a7f 100644
--- a/include/linux/security.h
+++ b/include/linux/security.h
@@ -987,10 +987,7 @@ static inline void security_free_mnt_opts(struct 
security_mnt_opts *opts)
  *     Retrieve the LSM-specific secid for the sock to enable caching of 
network
  *     authorizations.
  * @sock_graft:
- *     This hook is called in response to a newly created sock struct being
- *     grafted onto an existing socket and allows the security module to
- *     perform whatever security attribute management is necessary for both
- *     the sock and socket.
+ *     Sets the socket's isec sid to the sock's sid.
  * @inet_conn_request:
  *     Sets the openreq's sid to socket's sid with MLS portion taken from peer 
sid.
  * @inet_csk_clone:
diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c
index f66143d..019749c 100644
--- a/security/selinux/hooks.c
+++ b/security/selinux/hooks.c
@@ -4497,18 +4497,9 @@ static void selinux_sock_graft(struct sock *sk, struct 
socket *parent)
        struct inode_security_struct *isec = SOCK_INODE(parent)->i_security;
        struct sk_security_struct *sksec = sk->sk_security;
 
-       switch (sk->sk_family) {
-       case PF_INET:
-       case PF_INET6:
-       case PF_UNIX:
+       if (sk->sk_family == PF_INET || sk->sk_family == PF_INET6 ||
+           sk->sk_family == PF_UNIX)
                isec->sid = sksec->sid;
-               break;
-       default:
-               /* by default there is no special labeling mechanism for the
-                * sksec label so inherit the label from the parent socket */
-               BUG_ON(sksec->sid != SECINITSID_UNLABELED);
-               sksec->sid = isec->sid;
-       }
        sksec->sclass = isec->sclass;
 }
 
-- 
1.9.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to