Commit cee0c33
committed
cgroup: css_task_iter_skip()'d iterators must be advanced before accessed
b636fd3 ("cgroup: Implement css_task_iter_skip()") introduced
css_task_iter_skip() which is used to fix task iterations skipping
dying threadgroup leaders with live threads. Skipping is implemented
as a subportion of full advancing but css_task_iter_next() forgot to
fully advance a skipped iterator before determining the next task to
visit causing it to return invalid task pointers.
Fix it by making css_task_iter_next() fully advance the iterator if it
has been skipped since the previous iteration.
Signed-off-by: Tejun Heo <tj@kernel.org>
Reported-by: syzbot
Link: http://lkml.kernel.org/r/00000000000097025d058a7fd785@google.com
Fixes: b636fd3 ("cgroup: Implement css_task_iter_skip()")1 parent c03cd77 commit cee0c33
1 file changed
+4
-0
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4550 | 4550 | | |
4551 | 4551 | | |
4552 | 4552 | | |
| 4553 | + | |
| 4554 | + | |
| 4555 | + | |
| 4556 | + | |
4553 | 4557 | | |
4554 | 4558 | | |
4555 | 4559 | | |
| |||
0 commit comments