aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMikulas Patocka <mpatocka@redhat.com>2018-07-03 14:13:29 -0400
committerMike Snitzer <snitzer@redhat.com>2018-07-27 15:24:24 -0400
commit71e9ddbcb99e9bf1f968906b395e172ea8328365 (patch)
treed7f912802f7ec11d8936b32625ff40158b9d56fa
parentf84fd2c98480fa0e3c0b43996c4e235bdf4a9527 (diff)
dm integrity: add ic->start in get_data_sector()
A small refactoring. Add the variable ic->start to the result returned by get_data_sector() and not in the callers. This is a prerequisite for the commit that adds the ability to use an external metadata device. Signed-off-by: Mikulas Patocka <mpatocka@redhat.com> Signed-off-by: Mike Snitzer <snitzer@redhat.com>
-rw-r--r--drivers/md/dm-integrity.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/md/dm-integrity.c b/drivers/md/dm-integrity.c
index 09dadb771a62..39d465e92f74 100644
--- a/drivers/md/dm-integrity.c
+++ b/drivers/md/dm-integrity.c
@@ -394,6 +394,8 @@ static sector_t get_data_sector(struct dm_integrity_c *ic, sector_t area, sector
394 result += (area + 1) * ic->metadata_run; 394 result += (area + 1) * ic->metadata_run;
395 395
396 result += (sector_t)ic->initial_sectors + offset; 396 result += (sector_t)ic->initial_sectors + offset;
397 result += ic->start;
398
397 return result; 399 return result;
398} 400}
399 401
@@ -865,7 +867,7 @@ static void copy_from_journal(struct dm_integrity_c *ic, unsigned section, unsig
865 io_req.notify.context = data; 867 io_req.notify.context = data;
866 io_req.client = ic->io; 868 io_req.client = ic->io;
867 io_loc.bdev = ic->dev->bdev; 869 io_loc.bdev = ic->dev->bdev;
868 io_loc.sector = ic->start + target; 870 io_loc.sector = target;
869 io_loc.count = n_sectors; 871 io_loc.count = n_sectors;
870 872
871 r = dm_io(&io_req, 1, &io_loc, NULL); 873 r = dm_io(&io_req, 1, &io_loc, NULL);
@@ -1753,7 +1755,6 @@ offload_to_thread:
1753 bio->bi_end_io = integrity_end_io; 1755 bio->bi_end_io = integrity_end_io;
1754 1756
1755 bio->bi_iter.bi_size = dio->range.n_sectors << SECTOR_SHIFT; 1757 bio->bi_iter.bi_size = dio->range.n_sectors << SECTOR_SHIFT;
1756 bio->bi_iter.bi_sector += ic->start;
1757 generic_make_request(bio); 1758 generic_make_request(bio);
1758 1759
1759 if (need_sync_io) { 1760 if (need_sync_io) {
@@ -2391,7 +2392,7 @@ static int calculate_device_limits(struct dm_integrity_c *ic)
2391 get_area_and_offset(ic, ic->provided_data_sectors - 1, &last_area, &last_offset); 2392 get_area_and_offset(ic, ic->provided_data_sectors - 1, &last_area, &last_offset);
2392 last_sector = get_data_sector(ic, last_area, last_offset); 2393 last_sector = get_data_sector(ic, last_area, last_offset);
2393 2394
2394 if (ic->start + last_sector < last_sector || ic->start + last_sector >= ic->device_sectors) 2395 if (last_sector < ic->start || last_sector >= ic->device_sectors)
2395 return -EINVAL; 2396 return -EINVAL;
2396 2397
2397 return 0; 2398 return 0;