Jann Horn 0da74120c5 selinux: move user accesses in selinuxfs out of locked regions
If a user is accessing a file in selinuxfs with a pointer to a userspace
buffer that is backed by e.g. a userfaultfd, the userspace access can
stall indefinitely, which can block fsi->mutex if it is held.

For sel_read_policy(), remove the locking, since this method doesn't seem
to access anything that requires locking.

For sel_read_bool(), move the user access below the locked region.

For sel_write_bool() and sel_commit_bools_write(), move the user access
up above the locked region.

Cc: stable@vger.kernel.org
Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
Signed-off-by: Jann Horn <jannh@google.com>
Acked-by: Stephen Smalley <sds@tycho.nsa.gov>
[PM: removed an unused variable in sel_read_policy()]
Signed-off-by: Paul Moore <paul@paul-moore.com>
2018-06-28 20:39:54 -04:00
..
2018-04-06 15:39:26 -07:00
2018-03-20 16:58:17 -04:00
2018-03-20 16:58:17 -04:00
2018-03-01 18:48:02 -05:00
2018-03-01 18:48:02 -05:00
2018-03-20 16:58:17 -04:00
2018-03-01 18:48:02 -05:00
2018-03-01 18:48:02 -05:00
2018-03-20 16:58:17 -04:00