From b207c5ff8788c3cf3a1c65c3feb813b5746461e0 Mon Sep 17 00:00:00 2001 From: FUJITA Tomonori Date: Mon, 20 Oct 2008 14:43:47 +0900 Subject: [PATCH 1/9] dm snapshot: make chunk_io handle any buffer chunk_io() can perform I/Os only with ps->area. This patch adds a new argument (a pointer to a buffer) to chunk_io() so that it can performs I/Os with the buffer. Signed-off-by: FUJITA Tomonori --- drivers/md/dm-exception-store.c | 11 ++++++----- 1 files changed, 6 insertions(+), 5 deletions(-) diff --git a/drivers/md/dm-exception-store.c b/drivers/md/dm-exception-store.c index 01590f3..6c5ea26 100644 --- a/drivers/md/dm-exception-store.c +++ b/drivers/md/dm-exception-store.c @@ -188,7 +188,8 @@ static void do_metadata(struct work_struct *work) /* * Read or write a chunk aligned and sized block of data from a device. */ -static int chunk_io(struct pstore *ps, chunk_t chunk, int rw, int metadata) +static int chunk_io(struct pstore *ps, chunk_t chunk, int rw, int metadata, + void *data) { struct dm_io_region where = { .bdev = ps->snap->cow->bdev, @@ -198,7 +199,7 @@ static int chunk_io(struct pstore *ps, chunk_t chunk, int rw, int metadata) struct dm_io_request io_req = { .bi_rw = rw, .mem.type = DM_IO_VMA, - .mem.ptr.vma = ps->area, + .mem.ptr.vma = data, .client = ps->io_client, .notify.fn = NULL, }; @@ -240,7 +241,7 @@ static int area_io(struct pstore *ps, int rw) chunk = area_location(ps, ps->current_area); - r = chunk_io(ps, chunk, rw, 0); + r = chunk_io(ps, chunk, rw, 0, ps->area); if (r) return r; @@ -297,7 +298,7 @@ static int read_header(struct pstore *ps, int *new_snapshot) if (r) return r; - r = chunk_io(ps, 0, READ, 1); + r = chunk_io(ps, 0, READ, 1, ps->area); if (r) goto bad; @@ -359,7 +360,7 @@ static int write_header(struct pstore *ps) dh->version = cpu_to_le32(ps->version); dh->chunk_size = cpu_to_le32(ps->snap->chunk_size); - return chunk_io(ps, 0, WRITE, 1); + return chunk_io(ps, 0, WRITE, 1, ps->area); } /* -- 1.5.5.GIT