diff mbox

blk-mq: Fix poll_stat for new size-based bucketing.

Message ID 1492729151-20983-1-git-send-email-sbates@raithlin.com (mailing list archive)
State New, archived
Headers show

Commit Message

Stephen Bates April 20, 2017, 10:59 p.m. UTC
From: Stephen Bates <sbates@raithlin.com>

Fixes an issue where the size of the poll_stat array in request_queue
does not match the size expected by the new size based bucketing for
IO completion polling.

Should be applied on top of commit 720b8ccc4500 ("blk-mq: Add a
polling specific stats function").

Signed-off-by: Stephen Bates <sbates@raithlin.com>
---
 block/blk-mq-debugfs.c | 15 +++++++++------
 block/blk-mq.c         |  8 ++++----
 include/linux/blkdev.h |  5 ++++-
 3 files changed, 17 insertions(+), 11 deletions(-)

Comments

Jens Axboe April 20, 2017, 11:12 p.m. UTC | #1
On 04/20/2017 04:59 PM, sbates@raithlin.com wrote:
> From: Stephen Bates <sbates@raithlin.com>
> 
> Fixes an issue where the size of the poll_stat array in request_queue
> does not match the size expected by the new size based bucketing for
> IO completion polling.
> 
> Should be applied on top of commit 720b8ccc4500 ("blk-mq: Add a
> polling specific stats function").

Thanks, added. BTW, in the future, we have a format for specifying
if a patch fixes another patch. This should have been:

Fixes: 720b8ccc4500 ("blk-mq: Add a polling specific stats function")
Stephen Bates April 20, 2017, 11:13 p.m. UTC | #2
> Thanks, added. BTW, in the future, we have a format for specifying

> if a patch fixes another patch. This should have been:


Thanks!

> Fixes: 720b8ccc4500 ("blk-mq: Add a polling specific stats function")


Duly noted for next time. Apologies for the miss…
Jens Axboe April 20, 2017, 11:16 p.m. UTC | #3
On 04/20/2017 05:13 PM, Stephen  Bates wrote:
> 
>> Thanks, added. BTW, in the future, we have a format for specifying
>> if a patch fixes another patch. This should have been:
> 
> Thanks!
> 
>> Fixes: 720b8ccc4500 ("blk-mq: Add a polling specific stats function")
> 
> Duly noted for next time. Apologies for the miss…

No worries, I fixed it up for you while committing.
Sagi Grimberg April 20, 2017, 11:57 p.m. UTC | #4
>> Thanks, added. BTW, in the future, we have a format for specifying
>> if a patch fixes another patch. This should have been:
>
> Thanks!
>
>> Fixes: 720b8ccc4500 ("blk-mq: Add a polling specific stats function")
>
> Duly noted for next time. Apologies for the miss…

Stephen,

I recommend adding a pretty section to your gitconfig:

[pretty]
         fixes = Fixes: %h (\"%s\")

This way you can run:

git log --pretty=fixes <broken_commit_hash>^!

and get the format for free :)

Cheers,
Sagi.
Stephen Bates April 21, 2017, 9:26 a.m. UTC | #5
> I recommend adding a pretty section to your gitconfig:

>

>[pretty]

 >        fixes = Fixes: %h (\"%s\")


Thanks Sagi. Duly added!
diff mbox

Patch

diff --git a/block/blk-mq-debugfs.c b/block/blk-mq-debugfs.c
index df9b688..3057641 100644
--- a/block/blk-mq-debugfs.c
+++ b/block/blk-mq-debugfs.c
@@ -159,14 +159,17 @@  static void print_stat(struct seq_file *m, struct blk_rq_stat *stat)
 static int queue_poll_stat_show(struct seq_file *m, void *v)
 {
 	struct request_queue *q = m->private;
+	int bucket;
 
-	seq_puts(m, "read: ");
-	print_stat(m, &q->poll_stat[READ]);
-	seq_puts(m, "\n");
+	for (bucket = 0; bucket < BLK_MQ_POLL_STATS_BKTS/2; bucket++) {
+		seq_printf(m, "read  (%d Bytes): ", 1 << (9+bucket));
+		print_stat(m, &q->poll_stat[2*bucket]);
+		seq_puts(m, "\n");
 
-	seq_puts(m, "write: ");
-	print_stat(m, &q->poll_stat[WRITE]);
-	seq_puts(m, "\n");
+		seq_printf(m, "write (%d Bytes): ",  1 << (9+bucket));
+		print_stat(m, &q->poll_stat[2*bucket+1]);
+		seq_puts(m, "\n");
+	}
 	return 0;
 }
 
diff --git a/block/blk-mq.c b/block/blk-mq.c
index 9d7645f..81f7c99 100644
--- a/block/blk-mq.c
+++ b/block/blk-mq.c
@@ -42,8 +42,6 @@  static LIST_HEAD(all_q_list);
 static void blk_mq_poll_stats_start(struct request_queue *q);
 static void blk_mq_poll_stats_fn(struct blk_stat_callback *cb);
 
-/* Must be consisitent with function below */
-#define BLK_MQ_POLL_STATS_BKTS 16
 static int blk_mq_poll_stats_bkt(const struct request *rq)
 {
 	int ddir, bytes, bucket;
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h
index 6c4ab0d..6c24786 100644
--- a/include/linux/blkdev.h
+++ b/include/linux/blkdev.h
@@ -46,6 +46,9 @@  struct blk_stat_callback;
 #define BLKDEV_MIN_RQ	4
 #define BLKDEV_MAX_RQ	128	/* Default maximum */
 
+/* Must be consisitent with blk_mq_poll_stats_bkt() */
+#define BLK_MQ_POLL_STATS_BKTS 16
+
 /*
  * Maximum number of blkcg policies allowed to be registered concurrently.
  * Defined here to simplify include dependency.
@@ -517,7 +520,7 @@  struct request_queue {
 	int			poll_nsec;
 
 	struct blk_stat_callback	*poll_cb;
-	struct blk_rq_stat	poll_stat[2];
+	struct blk_rq_stat	poll_stat[BLK_MQ_POLL_STATS_BKTS];
 
 	struct timer_list	timeout;
 	struct work_struct	timeout_work;