mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 10:00:17 +00:00
device_cgroup: fix RCU imbalance in error case
commit0fcc4c8c04upstream. When dev_exception_add() returns an error (due to a failed memory allocation), make sure that we move the RCU preemption count back to where it was before we were called. We dropped the RCU read lock inside the loop body, so we can't just "break". sparse complains about this, too: $ make -s C=2 security/device_cgroup.o ./include/linux/rcupdate.h:647:9: warning: context imbalance in 'propagate_exception' - unexpected unlock Fixes:d591fb5661("device_cgroup: simplify cgroup tree walk in propagate_exception()") Cc: stable@vger.kernel.org Signed-off-by: Jann Horn <jannh@google.com> Acked-by: Michal Hocko <mhocko@suse.com> Signed-off-by: Tejun Heo <tj@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
74b4ef5df5
commit
65fce15dbd
@@ -560,7 +560,7 @@ static int propagate_exception(struct dev_cgroup *devcg_root,
|
||||
devcg->behavior == DEVCG_DEFAULT_ALLOW) {
|
||||
rc = dev_exception_add(devcg, ex);
|
||||
if (rc)
|
||||
break;
|
||||
return rc;
|
||||
} else {
|
||||
/*
|
||||
* in the other possible cases:
|
||||
|
||||
Reference in New Issue
Block a user