dm io: record eopnotsupp
Add another field, eopnotsupp_bits. It is subset of error_bits, representing regions that returned -EOPNOTSUPP. (The bit is set in both error_bits and eopnotsupp_bits). This value will be used in further patches. Signed-off-by: Mikulas Patocka <mpatocka@redhat.com> Signed-off-by: Alasdair G Kergon <agk@redhat.com>
This commit is contained in:
parent
494b3ee7d4
commit
5af443a7e1
@ -22,6 +22,7 @@ struct dm_io_client {
|
|||||||
/* FIXME: can we shrink this ? */
|
/* FIXME: can we shrink this ? */
|
||||||
struct io {
|
struct io {
|
||||||
unsigned long error_bits;
|
unsigned long error_bits;
|
||||||
|
unsigned long eopnotsupp_bits;
|
||||||
atomic_t count;
|
atomic_t count;
|
||||||
struct task_struct *sleeper;
|
struct task_struct *sleeper;
|
||||||
struct dm_io_client *client;
|
struct dm_io_client *client;
|
||||||
@ -107,8 +108,11 @@ static inline unsigned bio_get_region(struct bio *bio)
|
|||||||
*---------------------------------------------------------------*/
|
*---------------------------------------------------------------*/
|
||||||
static void dec_count(struct io *io, unsigned int region, int error)
|
static void dec_count(struct io *io, unsigned int region, int error)
|
||||||
{
|
{
|
||||||
if (error)
|
if (error) {
|
||||||
set_bit(region, &io->error_bits);
|
set_bit(region, &io->error_bits);
|
||||||
|
if (error == -EOPNOTSUPP)
|
||||||
|
set_bit(region, &io->eopnotsupp_bits);
|
||||||
|
}
|
||||||
|
|
||||||
if (atomic_dec_and_test(&io->count)) {
|
if (atomic_dec_and_test(&io->count)) {
|
||||||
if (io->sleeper)
|
if (io->sleeper)
|
||||||
@ -361,6 +365,7 @@ static int sync_io(struct dm_io_client *client, unsigned int num_regions,
|
|||||||
}
|
}
|
||||||
|
|
||||||
io.error_bits = 0;
|
io.error_bits = 0;
|
||||||
|
io.eopnotsupp_bits = 0;
|
||||||
atomic_set(&io.count, 1); /* see dispatch_io() */
|
atomic_set(&io.count, 1); /* see dispatch_io() */
|
||||||
io.sleeper = current;
|
io.sleeper = current;
|
||||||
io.client = client;
|
io.client = client;
|
||||||
@ -397,6 +402,7 @@ static int async_io(struct dm_io_client *client, unsigned int num_regions,
|
|||||||
|
|
||||||
io = mempool_alloc(client->pool, GFP_NOIO);
|
io = mempool_alloc(client->pool, GFP_NOIO);
|
||||||
io->error_bits = 0;
|
io->error_bits = 0;
|
||||||
|
io->eopnotsupp_bits = 0;
|
||||||
atomic_set(&io->count, 1); /* see dispatch_io() */
|
atomic_set(&io->count, 1); /* see dispatch_io() */
|
||||||
io->sleeper = NULL;
|
io->sleeper = NULL;
|
||||||
io->client = client;
|
io->client = client;
|
||||||
|
Loading…
Reference in New Issue
Block a user