summaryrefslogtreecommitdiffstats
path: root/sys/cam/ctl/ctl_backend_block.c
diff options
context:
space:
mode:
authormav <mav@FreeBSD.org>2015-05-13 15:23:53 +0000
committermav <mav@FreeBSD.org>2015-05-13 15:23:53 +0000
commit905de9c355df3c1d2c734f54ca369a5ffceb661c (patch)
tree11ee6df7e5decdbe1236de9497aac523ffc193f0 /sys/cam/ctl/ctl_backend_block.c
parent8e1b135fb3cb1e2b110d4b33750944465e5146a5 (diff)
downloadFreeBSD-src-905de9c355df3c1d2c734f54ca369a5ffceb661c.zip
FreeBSD-src-905de9c355df3c1d2c734f54ca369a5ffceb661c.tar.gz
MFC r282565: Handle EDQUOT backend storage errors same as ENOSPC.
Diffstat (limited to 'sys/cam/ctl/ctl_backend_block.c')
-rw-r--r--sys/cam/ctl/ctl_backend_block.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/sys/cam/ctl/ctl_backend_block.c b/sys/cam/ctl/ctl_backend_block.c
index 75dd0ad..2ec8ba7 100644
--- a/sys/cam/ctl/ctl_backend_block.c
+++ b/sys/cam/ctl/ctl_backend_block.c
@@ -524,7 +524,7 @@ ctl_be_block_biodone(struct bio *bio)
if (beio->num_errors > 0) {
if (error == EOPNOTSUPP) {
ctl_set_invalid_opcode(&io->scsiio);
- } else if (error == ENOSPC) {
+ } else if (error == ENOSPC || error == EDQUOT) {
ctl_set_space_alloc_fail(&io->scsiio);
} else if (beio->bio_cmd == BIO_FLUSH) {
/* XXX KDM is there is a better error here? */
@@ -741,7 +741,7 @@ ctl_be_block_dispatch_file(struct ctl_be_block_lun *be_lun,
ctl_scsi_path_string(io, path_str, sizeof(path_str));
printf("%s%s command returned errno %d\n", path_str,
(beio->bio_cmd == BIO_READ) ? "READ" : "WRITE", error);
- if (error == ENOSPC) {
+ if (error == ENOSPC || error == EDQUOT) {
ctl_set_space_alloc_fail(&io->scsiio);
} else
ctl_set_medium_error(&io->scsiio);
@@ -898,7 +898,7 @@ ctl_be_block_dispatch_zvol(struct ctl_be_block_lun *be_lun,
* return the I/O to the user.
*/
if (error != 0) {
- if (error == ENOSPC) {
+ if (error == ENOSPC || error == EDQUOT) {
ctl_set_space_alloc_fail(&io->scsiio);
} else
ctl_set_medium_error(&io->scsiio);
OpenPOWER on IntegriCloud