diff --git a/include/iscsi.h b/include/iscsi.h index c9e6ded..f8f3a66 100644 --- a/include/iscsi.h +++ b/include/iscsi.h @@ -264,6 +264,7 @@ EXTERN int iscsi_is_logged_in(struct iscsi_context *iscsi); enum scsi_status { SCSI_STATUS_GOOD = 0, SCSI_STATUS_CHECK_CONDITION = 2, + SCSI_STATUS_BUSY = 8, SCSI_STATUS_RESERVATION_CONFLICT = 0x18, SCSI_STATUS_REDIRECT = 0x101, SCSI_STATUS_CANCELLED = 0x0f000000, diff --git a/lib/iscsi-command.c b/lib/iscsi-command.c index 06d7d66..b687511 100644 --- a/lib/iscsi-command.c +++ b/lib/iscsi-command.c @@ -40,6 +40,7 @@ iscsi_scsi_response_cb(struct iscsi_context *iscsi, int status, case SCSI_STATUS_RESERVATION_CONFLICT: case SCSI_STATUS_CHECK_CONDITION: case SCSI_STATUS_GOOD: + case SCSI_STATUS_BUSY: case SCSI_STATUS_ERROR: case SCSI_STATUS_CANCELLED: scsi_cbdata->callback(iscsi, status, scsi_cbdata->task, @@ -395,6 +396,11 @@ iscsi_process_scsi_reply(struct iscsi_context *iscsi, struct iscsi_pdu *pdu, pdu->callback(iscsi, SCSI_STATUS_RESERVATION_CONFLICT, task, pdu->private_data); break; + case SCSI_STATUS_BUSY: + iscsi_set_error(iscsi, "BUSY"); + pdu->callback(iscsi, SCSI_STATUS_BUSY, + task, pdu->private_data); + break; default: iscsi_set_error(iscsi, "Unknown SCSI status :%d.", status);