diff options
| author | Chengming Zhou <[email protected]> | 2023-09-13 15:16:12 +0000 | 
|---|---|---|
| committer | Jens Axboe <[email protected]> | 2023-09-22 08:52:13 -0600 | 
| commit | b8643d682669994b3f57c3440df3d4f9cb735f35 (patch) | |
| tree | 35b49bc8dc17365c9e7dcbc74c71ee6cde581321 /scripts/gdb/linux/stackdepot.py | |
| parent | ce9ecca0238b140b88f43859b211c9fdfd8e5b70 (diff) | |
blk-mq: account active requests when get driver tag
There is a limit that batched queue_rqs() can't work on shared tags
queue, since the account of active requests can't be done there.
Now we account the active requests only in blk_mq_get_driver_tag(),
which is not the time we get driver tag actually (with none elevator).
To support batched queue_rqs() on shared tags queue, we move the
account of active requests to where we get the driver tag:
1. none elevator: blk_mq_get_tags() and blk_mq_get_tag()
2. other elevator: __blk_mq_alloc_driver_tag()
This is clearer and match with the unaccount side, which just happen
when we put the driver tag.
The other good point is that we don't need RQF_MQ_INFLIGHT trick
anymore, which used to avoid double account of flush request.
Now we only account when actually get the driver tag, so all is good.
We will remove RQF_MQ_INFLIGHT in the next patch.
Signed-off-by: Chengming Zhou <[email protected]>
Reviewed-by: Ming Lei <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Jens Axboe <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/stackdepot.py')
0 files changed, 0 insertions, 0 deletions