block/gluster: return correct error value

Upon error, gluster will call the aio callback function with a
ret value of -1, with errno set to the proper error value.  If
we set the acb->ret value to the return value in the callback,
that results in every error being EPERM (i.e. 1).  Instead, set
it to the proper error result.

Reviewed-by: Niels de Vos <ndevos@redhat.com>
Signed-off-by: Jeff Cody <jcody@redhat.com>
This commit is contained in:
Jeff Cody 2016-04-05 23:11:34 -04:00
parent d4dffa4a3f
commit a882745356

View File

@ -247,7 +247,7 @@ static void gluster_finish_aiocb(struct glfs_fd *fd, ssize_t ret, void *arg)
if (!ret || ret == acb->size) { if (!ret || ret == acb->size) {
acb->ret = 0; /* Success */ acb->ret = 0; /* Success */
} else if (ret < 0) { } else if (ret < 0) {
acb->ret = ret; /* Read/Write failed */ acb->ret = -errno; /* Read/Write failed */
} else { } else {
acb->ret = -EIO; /* Partial read/write - fail it */ acb->ret = -EIO; /* Partial read/write - fail it */
} }