Commit 981e8a98 authored by Mikulas Patocka's avatar Mikulas Patocka Committed by Mike Snitzer

dm integrity: introduce rw_journal_sectors()

Introduce a function rw_journal_sectors() that takes sector and length
as its arguments instead of a section and the number of sections.

This functions will be used in further patches.
Signed-off-by: default avatarMikulas Patocka <mpatocka@redhat.com>
Signed-off-by: default avatarMike Snitzer <snitzer@redhat.com>
parent 88ad5d1e
...@@ -761,12 +761,12 @@ static void complete_journal_io(unsigned long error, void *context) ...@@ -761,12 +761,12 @@ static void complete_journal_io(unsigned long error, void *context)
complete_journal_op(comp); complete_journal_op(comp);
} }
static void rw_journal(struct dm_integrity_c *ic, int op, int op_flags, unsigned section, static void rw_journal_sectors(struct dm_integrity_c *ic, int op, int op_flags,
unsigned n_sections, struct journal_completion *comp) unsigned sector, unsigned n_sectors, struct journal_completion *comp)
{ {
struct dm_io_request io_req; struct dm_io_request io_req;
struct dm_io_region io_loc; struct dm_io_region io_loc;
unsigned sector, n_sectors, pl_index, pl_offset; unsigned pl_index, pl_offset;
int r; int r;
if (unlikely(dm_integrity_failed(ic))) { if (unlikely(dm_integrity_failed(ic))) {
...@@ -775,9 +775,6 @@ static void rw_journal(struct dm_integrity_c *ic, int op, int op_flags, unsigned ...@@ -775,9 +775,6 @@ static void rw_journal(struct dm_integrity_c *ic, int op, int op_flags, unsigned
return; return;
} }
sector = section * ic->journal_section_sectors;
n_sectors = n_sections * ic->journal_section_sectors;
pl_index = sector >> (PAGE_SHIFT - SECTOR_SHIFT); pl_index = sector >> (PAGE_SHIFT - SECTOR_SHIFT);
pl_offset = (sector << SECTOR_SHIFT) & (PAGE_SIZE - 1); pl_offset = (sector << SECTOR_SHIFT) & (PAGE_SIZE - 1);
...@@ -810,6 +807,17 @@ static void rw_journal(struct dm_integrity_c *ic, int op, int op_flags, unsigned ...@@ -810,6 +807,17 @@ static void rw_journal(struct dm_integrity_c *ic, int op, int op_flags, unsigned
} }
} }
static void rw_journal(struct dm_integrity_c *ic, int op, int op_flags, unsigned section,
unsigned n_sections, struct journal_completion *comp)
{
unsigned sector, n_sectors;
sector = section * ic->journal_section_sectors;
n_sectors = n_sections * ic->journal_section_sectors;
rw_journal_sectors(ic, op, op_flags, sector, n_sectors, comp);
}
static void write_journal(struct dm_integrity_c *ic, unsigned commit_start, unsigned commit_sections) static void write_journal(struct dm_integrity_c *ic, unsigned commit_start, unsigned commit_sections)
{ {
struct journal_completion io_comp; struct journal_completion io_comp;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment