dm: fix missed error code if .end_io isn't implemented by target_type
In bio-based DM's clone_endio(), when target_type doesn't implement
.end_io (e.g. linear) r will be always be initialized 0. So if a
WRITE SAME bio fails WRITE SAME will not be disabled as intended.
Fix this by initializing r to error, rather than 0, in clone_endio().
Signed-off-by: Alex Chen <alex.chen@huawei.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Fixes: 7eee4ae2db
("dm: disable WRITE SAME if it fails")
Cc: stable@vger.kernel.org
This commit is contained in:
parent
2b94e8960c
commit
5164bece16
|
@ -899,7 +899,7 @@ static void disable_write_same(struct mapped_device *md)
|
||||||
|
|
||||||
static void clone_endio(struct bio *bio, int error)
|
static void clone_endio(struct bio *bio, int error)
|
||||||
{
|
{
|
||||||
int r = 0;
|
int r = error;
|
||||||
struct dm_target_io *tio = container_of(bio, struct dm_target_io, clone);
|
struct dm_target_io *tio = container_of(bio, struct dm_target_io, clone);
|
||||||
struct dm_io *io = tio->io;
|
struct dm_io *io = tio->io;
|
||||||
struct mapped_device *md = tio->io->md;
|
struct mapped_device *md = tio->io->md;
|
||||||
|
|
Loading…
Reference in New Issue