Hello Jens, This patch series contains one patch that reduces the size of struct blk_mq_hw_ctx, a few patches that simplify some of the block layer code and also patches that improve the block layer documentation. Please consider these patches for kernel v4.13. This patch series survives the following tests: srp-test/run_tests -r 30 -e none srp-test/run_tests -r 30 -e deadline srp-test/run_tests -r 30 -e kyber srp-test/run_tests -r 30 -e bfq The basis for these patches is your for-next branch. Thanks, Bart. Changes between v4 and v5: * Addressed Jens' and Hannes' review comments for v4 of this patch series. The most significant change is in patch "block: Introduce request_queue .initialize_rq_fn()". * Fixed a bug that was introduced in v3 due to rebasing in patch "blk-mq: Initialize .rq_flags in blk_mq_rq_ctx_init()", namely that the new .rq_flags assignment could clear the RQF_MQ_INFLIGHT flag. Changes between v3 and v4: * Rebased on top of Jens' current for-next branch. * Renamed patch "blk-mq: Initialize a request before assigning a tag" into "blk-mq: Initialize .rq_flags in blk_mq_rq_ctx_init()" and removed the __blk_mq_alloc_request() changes from that patch since these changes no longer apply to the current block layer code. Changes between v2 and v3: * Added patch "blk-mq: Reduce blk_mq_hw_ctx size". * Removed patch "block: Rename blk_mq_rq_{to,from}_pdu()". * Addressed Christoph's review comments about patch "block: Introduce request_queue.initialize_rq_fn()". * Rebased (and retested) this patch series on top of a merge of Jens' for-next and for-linus branches. Changes between v1 and v2: * Addressed Christoph's comment about moving the .initialize_rq_fn() call from blk_rq_init() / blk_mq_rq_ctx_init() into blk_get_request(). * Left out patch "scsi: Make scsi_ioctl_reset() pass the request queue pointer to blk_rq_init()" since it's no longer needed. * Restored the scsi_req_init() call in ide_prep_sense(). * Combined the two patches that reduce the blk_mq_hw_ctx size into a single patch. * Modified patch "blk-mq: Initialize a request before assigning a tag" such that .tag and .internal_tag are no longer initialized twice. * Removed WARN_ON_ONCE(q->mq_ops) from blk_queue_bypass_end() because this function is used by both blk-sq and blk-mq. * Added several new patches, e.g. "block: Rename blk_mq_rq_{to,from}_pdu()". Bart Van Assche (12): blk-mq: Reduce blk_mq_hw_ctx size block: Make request operation type argument declarations consistent block: Introduce request_queue.initialize_rq_fn() block: Make most scsi_req_init() calls implicit block: Change argument type of scsi_req_init() blk-mq: Initialize .rq_flags in blk_mq_rq_ctx_init() block: Add a comment above queue_lockdep_assert_held() block: Check locking assumptions at runtime block: Document what queue type each function is intended for blk-mq: Document locking assumptions block: Constify disk_type blk-mq: Warn when attempting to run a hardware queue that is not mapped block/blk-core.c | 130 ++++++++++++++++++++++++++++--------- block/blk-flush.c | 8 ++- block/blk-merge.c | 3 + block/blk-mq-sched.c | 2 + block/blk-mq.c | 55 +++++++++++----- block/blk-tag.c | 15 ++--- block/blk-timeout.c | 4 +- block/blk.h | 2 + block/bsg.c | 1 - block/genhd.c | 4 +- block/scsi_ioctl.c | 13 ++-- drivers/block/pktcdvd.c | 1 - drivers/cdrom/cdrom.c | 1 - drivers/ide/ide-atapi.c | 3 +- drivers/ide/ide-cd.c | 1 - drivers/ide/ide-cd_ioctl.c | 1 - drivers/ide/ide-devsets.c | 1 - drivers/ide/ide-disk.c | 1 - drivers/ide/ide-ioctls.c | 2 - drivers/ide/ide-park.c | 2 - drivers/ide/ide-pm.c | 2 - drivers/ide/ide-probe.c | 6 +- drivers/ide/ide-tape.c | 1 - drivers/ide/ide-taskfile.c | 1 - drivers/scsi/osd/osd_initiator.c | 2 - drivers/scsi/osst.c | 1 - drivers/scsi/scsi_error.c | 1 - drivers/scsi/scsi_lib.c | 17 ++++- drivers/scsi/scsi_transport_sas.c | 2 + drivers/scsi/sg.c | 2 - drivers/scsi/st.c | 1 - drivers/target/target_core_pscsi.c | 2 - fs/nfsd/blocklayout.c | 1 - include/linux/blk-mq.h | 13 ++-- include/linux/blkdev.h | 14 +++- include/scsi/scsi_cmnd.h | 1 + include/scsi/scsi_request.h | 2 +- 37 files changed, 211 insertions(+), 108 deletions(-) -- 2.13.1