diff options
author | Ming Lei <[email protected]> | 2021-01-22 10:33:12 +0800 |
---|---|---|
committer | Martin K. Petersen <[email protected]> | 2021-03-04 17:36:59 -0500 |
commit | 2a5a24aa83382a88c43d18a901fab66e6ffe1199 (patch) | |
tree | 85d9a1aa8d76bb25fe9fdc56f9a1b74f575ce485 /include/linux/overflow.h | |
parent | d022d18c045fc2ccf92d0f14cf80f98eb0a8e119 (diff) |
scsi: blk-mq: Return budget token from .get_budget callback
SCSI uses a global atomic variable to track queue depth for each
LUN/request queue.
This doesn't scale well when there are lots of CPU cores and the disk is
very fast. It has been observed that IOPS is affected a lot by tracking
queue depth via sdev->device_busy in the I/O path.
Return budget token from .get_budget callback. The budget token can be
passed to driver so that we can replace the atomic variable with
sbitmap_queue and alleviate the scaling problems that way.
Link: https://lore.kernel.org/r/[email protected]
Cc: Omar Sandoval <[email protected]>
Cc: Kashyap Desai <[email protected]>
Cc: Sumanesh Samanta <[email protected]>
Cc: Ewan D. Milne <[email protected]>
Tested-by: Sumanesh Samanta <[email protected]>
Reviewed-by: Hannes Reinecke <[email protected]>
Signed-off-by: Ming Lei <[email protected]>
Signed-off-by: Martin K. Petersen <[email protected]>
Diffstat (limited to 'include/linux/overflow.h')
0 files changed, 0 insertions, 0 deletions