There is a split tracepoint that is supposed to be called before
splitting a bio, and it was actually called in bio_split function
until commit 4b1faf931650d4a35b2a ("block: Kill bio_pair_split()").
But now, no one reports splits, so this patch adds calls to
trace_block_split back right before bio_split.

Signed-off-by: Mike Krinkin <krinkin....@gmail.com>
---
 block/blk-merge.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/block/blk-merge.c b/block/blk-merge.c
index de5716d8..832ec49 100644
--- a/block/blk-merge.c
+++ b/block/blk-merge.c
@@ -7,6 +7,8 @@
 #include <linux/blkdev.h>
 #include <linux/scatterlist.h>
 
+#include <trace/events/block.h>
+
 #include "blk.h"
 
 static struct bio *blk_bio_discard_split(struct request_queue *q,
@@ -49,6 +51,7 @@ static struct bio *blk_bio_discard_split(struct request_queue 
*q,
        if (split_sectors > tmp)
                split_sectors -= tmp;
 
+       trace_block_split(q, bio, bio->bi_iter.bi_sector + split_sectors);
        return bio_split(bio, split_sectors, GFP_NOIO, bs);
 }
 
@@ -65,6 +68,7 @@ static struct bio *blk_bio_write_same_split(struct 
request_queue *q,
        if (bio_sectors(bio) <= q->limits.max_write_same_sectors)
                return NULL;
 
+       trace_block_split(q, bio, bio->bi_iter.bi_sector);
        return bio_split(bio, q->limits.max_write_same_sectors, GFP_NOIO, bs);
 }
 
@@ -117,6 +121,7 @@ new_segment:
        return NULL;
 split:
        *segs = nsegs;
+       trace_block_split(q, bio, bio->bi_iter.bi_sector + sectors);
        return bio_split(bio, sectors, GFP_NOIO, bs);
 }
 
-- 
1.9.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to