From 8b7b6e4c32a88db70419efc1f1bc9f711337611d Mon Sep 17 00:00:00 2001 From: "Alan D. Brunelle" Date: Tue, 7 Aug 2007 15:30:23 +0200 Subject: [PATCH] --- yaml --- r: 63892 b: refs/heads/master c: c7149d6bce2561aeaa48caaa1700aa8b3b22008f h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/block/ll_rw_blk.c | 4 ++++ trunk/drivers/md/dm.c | 4 ++-- trunk/include/linux/blktrace_api.h | 3 ++- 4 files changed, 9 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 94b7201bb725..329b2b2f8f13 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: ec05b297f91a443aa26b74059b573bfad49c9ebb +refs/heads/master: c7149d6bce2561aeaa48caaa1700aa8b3b22008f diff --git a/trunk/block/ll_rw_blk.c b/trunk/block/ll_rw_blk.c index 8c2caff87cc3..a15845c164f2 100644 --- a/trunk/block/ll_rw_blk.c +++ b/trunk/block/ll_rw_blk.c @@ -3047,6 +3047,10 @@ static inline void blk_partition_remap(struct bio *bio) bio->bi_sector += p->start_sect; bio->bi_bdev = bdev->bd_contains; + + blk_add_trace_remap(bdev_get_queue(bio->bi_bdev), bio, + bdev->bd_dev, bio->bi_sector, + bio->bi_sector - p->start_sect); } } diff --git a/trunk/drivers/md/dm.c b/trunk/drivers/md/dm.c index 141ff9fa296e..2120155929a6 100644 --- a/trunk/drivers/md/dm.c +++ b/trunk/drivers/md/dm.c @@ -580,8 +580,8 @@ static void __map_bio(struct dm_target *ti, struct bio *clone, /* the bio has been remapped so dispatch it */ blk_add_trace_remap(bdev_get_queue(clone->bi_bdev), clone, - tio->io->bio->bi_bdev->bd_dev, sector, - clone->bi_sector); + tio->io->bio->bi_bdev->bd_dev, + clone->bi_sector, sector); generic_make_request(clone); } else if (r < 0 || r == DM_MAPIO_REQUEUE) { diff --git a/trunk/include/linux/blktrace_api.h b/trunk/include/linux/blktrace_api.h index 90874a5d7d78..7b5d56b82b59 100644 --- a/trunk/include/linux/blktrace_api.h +++ b/trunk/include/linux/blktrace_api.h @@ -105,7 +105,7 @@ struct blk_io_trace { */ struct blk_io_trace_remap { __be32 device; - u32 __pad; + __be32 device_from; __be64 sector; }; @@ -272,6 +272,7 @@ static inline void blk_add_trace_remap(struct request_queue *q, struct bio *bio, return; r.device = cpu_to_be32(dev); + r.device_from = cpu_to_be32(bio->bi_bdev->bd_dev); r.sector = cpu_to_be64(to); __blk_add_trace(bt, from, bio->bi_size, bio->bi_rw, BLK_TA_REMAP, !bio_flagged(bio, BIO_UPTODATE), sizeof(r), &r);