diff options
author | Mikulas Patocka <mpatocka@redhat.com> | 2018-07-03 14:13:29 -0400 |
---|---|---|
committer | Mike Snitzer <snitzer@redhat.com> | 2018-07-27 15:24:24 -0400 |
commit | 71e9ddbcb99e9bf1f968906b395e172ea8328365 (patch) | |
tree | d7f912802f7ec11d8936b32625ff40158b9d56fa | |
parent | f84fd2c98480fa0e3c0b43996c4e235bdf4a9527 (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.c | 7 |
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; |