Commit ba0ffdd8 authored by Jens Axboe's avatar Jens Axboe

block: bump max plugged deferred size from 16 to 32

Particularly for NVMe with efficient deferred submission for many
requests, there are nice benefits to be seen by bumping the default max
plug count from 16 to 32. This is especially true for virtualized setups,
where the submit part is more expensive. But can be noticed even on
native hardware.

Reduce the multiple queue factor from 4 to 2, since we're changing the
default size.

While changing it, move the defines into the block layer private header.
These aren't values that anyone outside of the block layer uses, or
should use.
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 00067077
...@@ -2152,14 +2152,14 @@ static void blk_add_rq_to_plug(struct blk_plug *plug, struct request *rq) ...@@ -2152,14 +2152,14 @@ static void blk_add_rq_to_plug(struct blk_plug *plug, struct request *rq)
} }
/* /*
* Allow 4x BLK_MAX_REQUEST_COUNT requests on plug queue for multiple * Allow 2x BLK_MAX_REQUEST_COUNT requests on plug queue for multiple
* queues. This is important for md arrays to benefit from merging * queues. This is important for md arrays to benefit from merging
* requests. * requests.
*/ */
static inline unsigned short blk_plug_max_rq_count(struct blk_plug *plug) static inline unsigned short blk_plug_max_rq_count(struct blk_plug *plug)
{ {
if (plug->multiple_queues) if (plug->multiple_queues)
return BLK_MAX_REQUEST_COUNT * 4; return BLK_MAX_REQUEST_COUNT * 2;
return BLK_MAX_REQUEST_COUNT; return BLK_MAX_REQUEST_COUNT;
} }
......
...@@ -224,6 +224,12 @@ bool blk_bio_list_merge(struct request_queue *q, struct list_head *list, ...@@ -224,6 +224,12 @@ bool blk_bio_list_merge(struct request_queue *q, struct list_head *list,
void blk_account_io_start(struct request *req); void blk_account_io_start(struct request *req);
void blk_account_io_done(struct request *req, u64 now); void blk_account_io_done(struct request *req, u64 now);
/*
* Plug flush limits
*/
#define BLK_MAX_REQUEST_COUNT 32
#define BLK_PLUG_FLUSH_SIZE (128 * 1024)
/* /*
* Internal elevator interface * Internal elevator interface
*/ */
......
...@@ -727,8 +727,6 @@ struct blk_plug { ...@@ -727,8 +727,6 @@ struct blk_plug {
bool multiple_queues; bool multiple_queues;
bool nowait; bool nowait;
}; };
#define BLK_MAX_REQUEST_COUNT 16
#define BLK_PLUG_FLUSH_SIZE (128 * 1024)
struct blk_plug_cb; struct blk_plug_cb;
typedef void (*blk_plug_cb_fn)(struct blk_plug_cb *, bool); typedef void (*blk_plug_cb_fn)(struct blk_plug_cb *, bool);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment