[dm-devel] [PATCH 3/5] block: remove the request_queue argument to the block_split tracepoint
Damien Le Moal
Damien.LeMoal at wdc.com
Thu Dec 3 08:59:11 UTC 2020
On 2020/12/01 3:09, Christoph Hellwig wrote:
> The request_queue can trivially be derived from the bio.
>
> Signed-off-by: Christoph Hellwig <hch at lst.de>
> ---
> block/blk-merge.c | 2 +-
> drivers/md/dm.c | 2 +-
> include/trace/events/block.h | 14 ++++++--------
> kernel/trace/blktrace.c | 5 ++---
> 4 files changed, 10 insertions(+), 13 deletions(-)
>
> diff --git a/block/blk-merge.c b/block/blk-merge.c
> index 1a46d5bbd399e3..4071daa88a5eaf 100644
> --- a/block/blk-merge.c
> +++ b/block/blk-merge.c
> @@ -338,7 +338,7 @@ void __blk_queue_split(struct bio **bio, unsigned int *nr_segs)
> split->bi_opf |= REQ_NOMERGE;
>
> bio_chain(split, *bio);
> - trace_block_split(q, split, (*bio)->bi_iter.bi_sector);
> + trace_block_split(split, (*bio)->bi_iter.bi_sector);
> submit_bio_noacct(*bio);
> *bio = split;
> }
> diff --git a/drivers/md/dm.c b/drivers/md/dm.c
> index ed7e836efbcdbc..9a5bd90779c7c4 100644
> --- a/drivers/md/dm.c
> +++ b/drivers/md/dm.c
> @@ -1612,7 +1612,7 @@ static blk_qc_t __split_and_process_bio(struct mapped_device *md,
> part_stat_unlock();
>
> bio_chain(b, bio);
> - trace_block_split(md->queue, b, bio->bi_iter.bi_sector);
> + trace_block_split(b, bio->bi_iter.bi_sector);
> ret = submit_bio_noacct(bio);
> break;
> }
> diff --git a/include/trace/events/block.h b/include/trace/events/block.h
> index 506c29dc7c76fd..b415e4cba84304 100644
> --- a/include/trace/events/block.h
> +++ b/include/trace/events/block.h
> @@ -411,21 +411,19 @@ DEFINE_EVENT(block_unplug, block_unplug,
>
> /**
> * block_split - split a single bio struct into two bio structs
> - * @q: queue containing the bio
> * @bio: block operation being split
> * @new_sector: The starting sector for the new bio
> *
> - * The bio request @bio in request queue @q needs to be split into two
> - * bio requests. The newly created @bio request starts at
> - * @new_sector. This split may be required due to hardware limitation
> - * such as operation crossing device boundaries in a RAID system.
> + * The bio request @bio needs to be split into two bio requests. The newly
> + * created @bio request starts at @new_sector. This split may be required due to
> + * hardware limitations such as operation crossing device boundaries in a RAID
> + * system.
> */
> TRACE_EVENT(block_split,
>
> - TP_PROTO(struct request_queue *q, struct bio *bio,
> - unsigned int new_sector),
> + TP_PROTO(struct bio *bio, unsigned int new_sector),
>
> - TP_ARGS(q, bio, new_sector),
> + TP_ARGS(bio, new_sector),
>
> TP_STRUCT__entry(
> __field( dev_t, dev )
> diff --git a/kernel/trace/blktrace.c b/kernel/trace/blktrace.c
> index 7ab88e00c15765..3ca6d62114f461 100644
> --- a/kernel/trace/blktrace.c
> +++ b/kernel/trace/blktrace.c
> @@ -970,10 +970,9 @@ static void blk_add_trace_unplug(void *ignore, struct request_queue *q,
> rcu_read_unlock();
> }
>
> -static void blk_add_trace_split(void *ignore,
> - struct request_queue *q, struct bio *bio,
> - unsigned int pdu)
> +static void blk_add_trace_split(void *ignore, struct bio *bio, unsigned int pdu)
> {
> + struct request_queue *q = bio->bi_disk->queue;
> struct blk_trace *bt;
>
> rcu_read_lock();
>
Looks good.
Reviewed-by: Damien Le Moal <damien.lemoal at wdc.com>
--
Damien Le Moal
Western Digital Research
More information about the dm-devel
mailing list