diff options
Diffstat (limited to 'security')
-rw-r--r-- | security/selinux/hooks.c | 13 |
1 files changed, 2 insertions, 11 deletions
diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c index 7740f61588d6..b0e940497e23 100644 --- a/security/selinux/hooks.c +++ b/security/selinux/hooks.c | |||
@@ -4510,18 +4510,9 @@ static void selinux_sock_graft(struct sock *sk, struct socket *parent) | |||
4510 | struct inode_security_struct *isec = SOCK_INODE(parent)->i_security; | 4510 | struct inode_security_struct *isec = SOCK_INODE(parent)->i_security; |
4511 | struct sk_security_struct *sksec = sk->sk_security; | 4511 | struct sk_security_struct *sksec = sk->sk_security; |
4512 | 4512 | ||
4513 | switch (sk->sk_family) { | 4513 | if (sk->sk_family == PF_INET || sk->sk_family == PF_INET6 || |
4514 | case PF_INET: | 4514 | sk->sk_family == PF_UNIX) |
4515 | case PF_INET6: | ||
4516 | case PF_UNIX: | ||
4517 | isec->sid = sksec->sid; | 4515 | isec->sid = sksec->sid; |
4518 | break; | ||
4519 | default: | ||
4520 | /* by default there is no special labeling mechanism for the | ||
4521 | * sksec label so inherit the label from the parent socket */ | ||
4522 | BUG_ON(sksec->sid != SECINITSID_UNLABELED); | ||
4523 | sksec->sid = isec->sid; | ||
4524 | } | ||
4525 | sksec->sclass = isec->sclass; | 4516 | sksec->sclass = isec->sclass; |
4526 | } | 4517 | } |
4527 | 4518 | ||