block/iscsi: only report an iSCSI Failure if we don't handle it gracefully
we currently report an "iSCSI Failure" in iscsi_co_generic_cb if the task hasn't completed with SCSI_STATUS_GOOD. However, we expect a failure in some cases and handle it gracefully. This is the case for misaligned UNMAPs and WRITESAME10/16 calls without UNMAP. In this case a failure in the logs can be quite misleading. While we are at it improve the logging to reveal which operation failed at what LBA. Signed-off-by: Peter Lieven <pl@kamp.de> Message-Id: <1512733868-9009-3-git-send-email-pl@kamp.de> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
aef172ffdc
commit
e38bc23454
|
@ -104,6 +104,7 @@ typedef struct IscsiTask {
|
||||||
IscsiLun *iscsilun;
|
IscsiLun *iscsilun;
|
||||||
QEMUTimer retry_timer;
|
QEMUTimer retry_timer;
|
||||||
int err_code;
|
int err_code;
|
||||||
|
char *err_str;
|
||||||
} IscsiTask;
|
} IscsiTask;
|
||||||
|
|
||||||
typedef struct IscsiAIOCB {
|
typedef struct IscsiAIOCB {
|
||||||
|
@ -265,7 +266,7 @@ iscsi_co_generic_cb(struct iscsi_context *iscsi, int status,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
iTask->err_code = iscsi_translate_sense(&task->sense);
|
iTask->err_code = iscsi_translate_sense(&task->sense);
|
||||||
error_report("iSCSI Failure: %s", iscsi_get_error(iscsi));
|
iTask->err_str = g_strdup(iscsi_get_error(iscsi));
|
||||||
}
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
|
@ -629,6 +630,8 @@ retry:
|
||||||
|
|
||||||
if (iTask.status != SCSI_STATUS_GOOD) {
|
if (iTask.status != SCSI_STATUS_GOOD) {
|
||||||
iscsi_allocmap_set_invalid(iscsilun, sector_num, nb_sectors);
|
iscsi_allocmap_set_invalid(iscsilun, sector_num, nb_sectors);
|
||||||
|
error_report("iSCSI WRITE10/16 failed at lba %" PRIu64 ": %s", lba,
|
||||||
|
iTask.err_str);
|
||||||
r = iTask.err_code;
|
r = iTask.err_code;
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
@ -637,6 +640,7 @@ retry:
|
||||||
|
|
||||||
out_unlock:
|
out_unlock:
|
||||||
qemu_mutex_unlock(&iscsilun->mutex);
|
qemu_mutex_unlock(&iscsilun->mutex);
|
||||||
|
g_free(iTask.err_str);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -651,10 +655,9 @@ static int64_t coroutine_fn iscsi_co_get_block_status(BlockDriverState *bs,
|
||||||
struct scsi_get_lba_status *lbas = NULL;
|
struct scsi_get_lba_status *lbas = NULL;
|
||||||
struct scsi_lba_status_descriptor *lbasd = NULL;
|
struct scsi_lba_status_descriptor *lbasd = NULL;
|
||||||
struct IscsiTask iTask;
|
struct IscsiTask iTask;
|
||||||
|
uint64_t lba;
|
||||||
int64_t ret;
|
int64_t ret;
|
||||||
|
|
||||||
iscsi_co_init_iscsitask(iscsilun, &iTask);
|
|
||||||
|
|
||||||
if (!is_sector_request_lun_aligned(sector_num, nb_sectors, iscsilun)) {
|
if (!is_sector_request_lun_aligned(sector_num, nb_sectors, iscsilun)) {
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -670,11 +673,13 @@ static int64_t coroutine_fn iscsi_co_get_block_status(BlockDriverState *bs,
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
lba = sector_qemu2lun(sector_num, iscsilun);
|
||||||
|
|
||||||
|
iscsi_co_init_iscsitask(iscsilun, &iTask);
|
||||||
qemu_mutex_lock(&iscsilun->mutex);
|
qemu_mutex_lock(&iscsilun->mutex);
|
||||||
retry:
|
retry:
|
||||||
if (iscsi_get_lba_status_task(iscsilun->iscsi, iscsilun->lun,
|
if (iscsi_get_lba_status_task(iscsilun->iscsi, iscsilun->lun,
|
||||||
sector_qemu2lun(sector_num, iscsilun),
|
lba, 8 + 16, iscsi_co_generic_cb,
|
||||||
8 + 16, iscsi_co_generic_cb,
|
|
||||||
&iTask) == NULL) {
|
&iTask) == NULL) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
|
@ -701,6 +706,8 @@ retry:
|
||||||
* because the device is busy or the cmd is not
|
* because the device is busy or the cmd is not
|
||||||
* supported) we pretend all blocks are allocated
|
* supported) we pretend all blocks are allocated
|
||||||
* for backwards compatibility */
|
* for backwards compatibility */
|
||||||
|
error_report("iSCSI GET_LBA_STATUS failed at lba %" PRIu64 ": %s",
|
||||||
|
lba, iTask.err_str);
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -738,6 +745,7 @@ retry:
|
||||||
}
|
}
|
||||||
out_unlock:
|
out_unlock:
|
||||||
qemu_mutex_unlock(&iscsilun->mutex);
|
qemu_mutex_unlock(&iscsilun->mutex);
|
||||||
|
g_free(iTask.err_str);
|
||||||
out:
|
out:
|
||||||
if (iTask.task != NULL) {
|
if (iTask.task != NULL) {
|
||||||
scsi_free_scsi_task(iTask.task);
|
scsi_free_scsi_task(iTask.task);
|
||||||
|
@ -756,6 +764,7 @@ static int coroutine_fn iscsi_co_readv(BlockDriverState *bs,
|
||||||
struct IscsiTask iTask;
|
struct IscsiTask iTask;
|
||||||
uint64_t lba;
|
uint64_t lba;
|
||||||
uint32_t num_sectors;
|
uint32_t num_sectors;
|
||||||
|
int r = 0;
|
||||||
|
|
||||||
if (!is_sector_request_lun_aligned(sector_num, nb_sectors, iscsilun)) {
|
if (!is_sector_request_lun_aligned(sector_num, nb_sectors, iscsilun)) {
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -853,19 +862,23 @@ retry:
|
||||||
iTask.complete = 0;
|
iTask.complete = 0;
|
||||||
goto retry;
|
goto retry;
|
||||||
}
|
}
|
||||||
qemu_mutex_unlock(&iscsilun->mutex);
|
|
||||||
|
|
||||||
if (iTask.status != SCSI_STATUS_GOOD) {
|
if (iTask.status != SCSI_STATUS_GOOD) {
|
||||||
return iTask.err_code;
|
error_report("iSCSI READ10/16 failed at lba %" PRIu64 ": %s",
|
||||||
|
lba, iTask.err_str);
|
||||||
|
r = iTask.err_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
qemu_mutex_unlock(&iscsilun->mutex);
|
||||||
|
g_free(iTask.err_str);
|
||||||
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int coroutine_fn iscsi_co_flush(BlockDriverState *bs)
|
static int coroutine_fn iscsi_co_flush(BlockDriverState *bs)
|
||||||
{
|
{
|
||||||
IscsiLun *iscsilun = bs->opaque;
|
IscsiLun *iscsilun = bs->opaque;
|
||||||
struct IscsiTask iTask;
|
struct IscsiTask iTask;
|
||||||
|
int r = 0;
|
||||||
|
|
||||||
iscsi_co_init_iscsitask(iscsilun, &iTask);
|
iscsi_co_init_iscsitask(iscsilun, &iTask);
|
||||||
qemu_mutex_lock(&iscsilun->mutex);
|
qemu_mutex_lock(&iscsilun->mutex);
|
||||||
|
@ -892,13 +905,15 @@ retry:
|
||||||
iTask.complete = 0;
|
iTask.complete = 0;
|
||||||
goto retry;
|
goto retry;
|
||||||
}
|
}
|
||||||
qemu_mutex_unlock(&iscsilun->mutex);
|
|
||||||
|
|
||||||
if (iTask.status != SCSI_STATUS_GOOD) {
|
if (iTask.status != SCSI_STATUS_GOOD) {
|
||||||
return iTask.err_code;
|
error_report("iSCSI SYNCHRONIZECACHE10 failed: %s", iTask.err_str);
|
||||||
|
r = iTask.err_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
qemu_mutex_unlock(&iscsilun->mutex);
|
||||||
|
g_free(iTask.err_str);
|
||||||
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
|
@ -1139,12 +1154,15 @@ retry:
|
||||||
}
|
}
|
||||||
|
|
||||||
if (iTask.status != SCSI_STATUS_GOOD) {
|
if (iTask.status != SCSI_STATUS_GOOD) {
|
||||||
|
error_report("iSCSI UNMAP failed at lba %" PRIu64 ": %s",
|
||||||
|
list.lba, iTask.err_str);
|
||||||
r = iTask.err_code;
|
r = iTask.err_code;
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
out_unlock:
|
out_unlock:
|
||||||
qemu_mutex_unlock(&iscsilun->mutex);
|
qemu_mutex_unlock(&iscsilun->mutex);
|
||||||
|
g_free(iTask.err_str);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1241,6 +1259,8 @@ retry:
|
||||||
if (iTask.status != SCSI_STATUS_GOOD) {
|
if (iTask.status != SCSI_STATUS_GOOD) {
|
||||||
iscsi_allocmap_set_invalid(iscsilun, offset >> BDRV_SECTOR_BITS,
|
iscsi_allocmap_set_invalid(iscsilun, offset >> BDRV_SECTOR_BITS,
|
||||||
bytes >> BDRV_SECTOR_BITS);
|
bytes >> BDRV_SECTOR_BITS);
|
||||||
|
error_report("iSCSI WRITESAME10/16 failed at lba %" PRIu64 ": %s",
|
||||||
|
lba, iTask.err_str);
|
||||||
r = iTask.err_code;
|
r = iTask.err_code;
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
@ -1255,6 +1275,7 @@ retry:
|
||||||
|
|
||||||
out_unlock:
|
out_unlock:
|
||||||
qemu_mutex_unlock(&iscsilun->mutex);
|
qemu_mutex_unlock(&iscsilun->mutex);
|
||||||
|
g_free(iTask.err_str);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue