bio: always copy back data for copied kernel requests
When a read bio_copy_kern() request fails, the content of the bounce buffer is not copied back. However, as request failure doesn't necessarily mean complete failure, the buffer state can be useful. This behavior is also inconsistent with the user map counterpart and causes the subtle difference between bounced and unbounced IO causes confusion. This patch makes bio_copy_kern_endio() ignore @err and always copy back data on request completion. Signed-off-by: Tejun Heo <tj@kernel.org> Cc: Boaz Harrosh <bharrosh@panasas.com> Cc: James Bottomley <James.Bottomley@HansenPartnership.com> Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
This commit is contained in:
parent
5f49f63178
commit
4fc981ef9e
1 changed files with 1 additions and 1 deletions
2
fs/bio.c
2
fs/bio.c
|
@ -1198,7 +1198,7 @@ static void bio_copy_kern_endio(struct bio *bio, int err)
|
|||
char *addr = page_address(bvec->bv_page);
|
||||
int len = bmd->iovecs[i].bv_len;
|
||||
|
||||
if (read && !err)
|
||||
if (read)
|
||||
memcpy(p, addr, len);
|
||||
|
||||
__free_page(bvec->bv_page);
|
||||
|
|
Loading…
Reference in a new issue