Fix selinux sock_graft hook for AF_ALG address family (rhbz 1115120)
This commit is contained in:
parent
f12a594c2d
commit
d35b963d10
@ -642,6 +642,9 @@ Patch25118: sched-fix-sched_setparam-policy-1-logic.patch
|
|||||||
#CVE-2014-5045 rhbz 1122472 1122482
|
#CVE-2014-5045 rhbz 1122472 1122482
|
||||||
Patch25119: fs-umount-on-symlink-leaks-mnt-count.patch
|
Patch25119: fs-umount-on-symlink-leaks-mnt-count.patch
|
||||||
|
|
||||||
|
#rhbz 1115120
|
||||||
|
Patch25120: selinux-4da6daf4d3df5a977e4623963f141a627fd2efce.patch
|
||||||
|
|
||||||
# git clone ssh://git.fedorahosted.org/git/kernel-arm64.git, git diff master...devel
|
# git clone ssh://git.fedorahosted.org/git/kernel-arm64.git, git diff master...devel
|
||||||
Patch30000: kernel-arm64.patch
|
Patch30000: kernel-arm64.patch
|
||||||
|
|
||||||
@ -1370,6 +1373,9 @@ ApplyPatch sched-fix-sched_setparam-policy-1-logic.patch
|
|||||||
#CVE-2014-5045 rhbz 1122472 1122482
|
#CVE-2014-5045 rhbz 1122472 1122482
|
||||||
ApplyPatch fs-umount-on-symlink-leaks-mnt-count.patch
|
ApplyPatch fs-umount-on-symlink-leaks-mnt-count.patch
|
||||||
|
|
||||||
|
#rhbz 1115120
|
||||||
|
ApplyPatch selinux-4da6daf4d3df5a977e4623963f141a627fd2efce.patch
|
||||||
|
|
||||||
%if 0%{?aarch64patches}
|
%if 0%{?aarch64patches}
|
||||||
ApplyPatch kernel-arm64.patch
|
ApplyPatch kernel-arm64.patch
|
||||||
%ifnarch aarch64 # this is stupid, but i want to notice before secondary koji does.
|
%ifnarch aarch64 # this is stupid, but i want to notice before secondary koji does.
|
||||||
@ -2252,6 +2258,9 @@ fi
|
|||||||
# ||----w |
|
# ||----w |
|
||||||
# || ||
|
# || ||
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Jul 25 2014 Josh Boyer <jwboyer@fedoraproject.org>
|
||||||
|
- Fix selinux sock_graft hook for AF_ALG address family (rhbz 1115120)
|
||||||
|
|
||||||
* Thu Jul 24 2014 Kyle McMartin <kyle@fedoraproject.org>
|
* Thu Jul 24 2014 Kyle McMartin <kyle@fedoraproject.org>
|
||||||
- kernel-arm64.patch: update from upstream git.
|
- kernel-arm64.patch: update from upstream git.
|
||||||
- arm64: update config-arm64 to include PCI support.
|
- arm64: update config-arm64 to include PCI support.
|
||||||
|
75
selinux-4da6daf4d3df5a977e4623963f141a627fd2efce.patch
Normal file
75
selinux-4da6daf4d3df5a977e4623963f141a627fd2efce.patch
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
Bugzilla: 1115120
|
||||||
|
Upstream-status: sent for 3.16
|
||||||
|
|
||||||
|
From 4da6daf4d3df5a977e4623963f141a627fd2efce Mon Sep 17 00:00:00 2001
|
||||||
|
From: Paul Moore <pmoore@redhat.com>
|
||||||
|
Date: Thu, 10 Jul 2014 10:17:48 -0400
|
||||||
|
Subject: [PATCH] selinux: fix the default socket labeling in sock_graft()
|
||||||
|
|
||||||
|
The sock_graft() hook has special handling for AF_INET, AF_INET, and
|
||||||
|
AF_UNIX sockets as those address families have special hooks which
|
||||||
|
label the sock before it is attached its associated socket.
|
||||||
|
Unfortunately, the sock_graft() hook was missing a default approach
|
||||||
|
to labeling sockets which meant that any other address family which
|
||||||
|
made use of connections or the accept() syscall would find the
|
||||||
|
returned socket to be in an "unlabeled" state. This was recently
|
||||||
|
demonstrated by the kcrypto/AF_ALG subsystem and the newly released
|
||||||
|
cryptsetup package (cryptsetup v1.6.5 and later).
|
||||||
|
|
||||||
|
This patch preserves the special handling in selinux_sock_graft(),
|
||||||
|
but adds a default behavior - setting the sock's label equal to the
|
||||||
|
associated socket - which resolves the problem with AF_ALG and
|
||||||
|
presumably any other address family which makes use of accept().
|
||||||
|
|
||||||
|
Cc: stable@vger.kernel.org
|
||||||
|
Signed-off-by: Paul Moore <pmoore@redhat.com>
|
||||||
|
Tested-by: Milan Broz <gmazyland@gmail.com>
|
||||||
|
---
|
||||||
|
include/linux/security.h | 5 ++++-
|
||||||
|
security/selinux/hooks.c | 13 +++++++++++--
|
||||||
|
2 files changed, 15 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/include/linux/security.h b/include/linux/security.h
|
||||||
|
index 6478ce3..794be73 100644
|
||||||
|
--- a/include/linux/security.h
|
||||||
|
+++ b/include/linux/security.h
|
||||||
|
@@ -987,7 +987,10 @@ 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:
|
||||||
|
- * Sets the socket's isec sid to the sock's sid.
|
||||||
|
+ * 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.
|
||||||
|
* @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 336f0a0..b3a6754 100644
|
||||||
|
--- a/security/selinux/hooks.c
|
||||||
|
+++ b/security/selinux/hooks.c
|
||||||
|
@@ -4499,9 +4499,18 @@ 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;
|
||||||
|
|
||||||
|
- if (sk->sk_family == PF_INET || sk->sk_family == PF_INET6 ||
|
||||||
|
- sk->sk_family == PF_UNIX)
|
||||||
|
+ switch (sk->sk_family) {
|
||||||
|
+ case PF_INET:
|
||||||
|
+ case PF_INET6:
|
||||||
|
+ case 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.3
|
||||||
|
|
Loading…
Reference in New Issue
Block a user