diff options
author | Christoph Hellwig <hch@lst.de> | 2014-04-25 02:32:53 -0700 |
---|---|---|
committer | Jens Axboe <axboe@fb.com> | 2014-04-25 08:24:07 -0600 |
commit | 38535201633077cbaf8b32886b5e3005b36c9024 (patch) | |
tree | ad94c4a3d3d7e1b47f2721ac36ab1698349e208d /include/linux/blk-mq.h | |
parent | 87ee7b112193bd081ba1a171fa5f6f39c429ef56 (diff) | |
download | op-kernel-dev-38535201633077cbaf8b32886b5e3005b36c9024.zip op-kernel-dev-38535201633077cbaf8b32886b5e3005b36c9024.tar.gz |
blk-mq: respect rq_affinity
The blk-mq code is using it's own version of the I/O completion affinity
tunables, which causes a few issues:
- the rq_affinity sysfs file doesn't work for blk-mq devices, even if it
still is present, thus breaking existing tuning setups.
- the rq_affinity = 1 mode, which is the defauly for legacy request based
drivers isn't implemented at all.
- blk-mq drivers don't implement any completion affinity with the default
flag settings.
This patches removes the blk-mq ipi_redirect flag and sysfs file, as well
as the internal BLK_MQ_F_SHOULD_IPI flag and replaces it with code that
respects the queue-wide rq_affinity flags and also implements the
rq_affinity = 1 mode.
This means I/O completion affinity can now only be tuned block-queue wide
instead of per context, which seems more sensible to me anyway.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'include/linux/blk-mq.h')
-rw-r--r-- | include/linux/blk-mq.h | 1 |
1 files changed, 0 insertions, 1 deletions
diff --git a/include/linux/blk-mq.h b/include/linux/blk-mq.h index ab469d5..3b561d6 100644 --- a/include/linux/blk-mq.h +++ b/include/linux/blk-mq.h @@ -122,7 +122,6 @@ enum { BLK_MQ_F_SHOULD_MERGE = 1 << 0, BLK_MQ_F_SHOULD_SORT = 1 << 1, - BLK_MQ_F_SHOULD_IPI = 1 << 2, BLK_MQ_S_STOPPED = 0, |