diff options
author | Jens Axboe <[email protected]> | 2018-08-26 10:10:05 -0600 |
---|---|---|
committer | Jens Axboe <[email protected]> | 2018-08-27 11:27:26 -0600 |
commit | 38cfb5a45ee013bfab5d1ae4c4738815e744b440 (patch) | |
tree | a85aa2ef3699f6a42256efbf23705993f6da6d98 /tools/perf/scripts/python/arm-cs-trace-disasm.py | |
parent | 061a5427530633de93ace4ef001b99961984af62 (diff) |
blk-wbt: improve waking of tasks
We have two potential issues:
1) After commit 2887e41b910b, we only wake one process at the time when
we finish an IO. We really want to wake up as many tasks as can
queue IO. Before this commit, we woke up everyone, which could cause
a thundering herd issue.
2) A task can potentially consume two wakeups, causing us to (in
practice) miss a wakeup.
Fix both by providing our own wakeup function, which stops
__wake_up_common() from waking up more tasks if we fail to get a
queueing token. With the strict ordering we have on the wait list, this
wakes the right tasks and the right amount of tasks.
Based on a patch from Jianchao Wang <[email protected]>.
Tested-by: Agarwal, Anchal <[email protected]>
Signed-off-by: Jens Axboe <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/arm-cs-trace-disasm.py')
0 files changed, 0 insertions, 0 deletions