From 739df2150d7e6291d54b3d2dcbd9ed52078e991c Mon Sep 17 00:00:00 2001 From: Paolo Bonzini Date: Wed, 3 Aug 2011 10:49:15 +0200 Subject: scsi: move handling of REQUEST SENSE to common code Signed-off-by: Paolo Bonzini Signed-off-by: Anthony Liguori --- hw/scsi-bus.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) (limited to 'hw/scsi-bus.c') diff --git a/hw/scsi-bus.c b/hw/scsi-bus.c index 8b229af989..ab45226507 100644 --- a/hw/scsi-bus.c +++ b/hw/scsi-bus.c @@ -270,6 +270,13 @@ static int32_t scsi_target_send_command(SCSIRequest *req, uint8_t *buf) goto illegal_request; } break; + case REQUEST_SENSE: + if (req->cmd.xfer < 4) { + goto illegal_request; + } + r->len = scsi_device_get_sense(r->req.dev, r->buf, req->cmd.xfer, + (req->cmd.buf[1] & 1) == 0); + break; default: scsi_req_build_sense(req, SENSE_CODE(LUN_NOT_SUPPORTED)); scsi_req_complete(req, CHECK_CONDITION); @@ -351,8 +358,9 @@ SCSIRequest *scsi_req_new(SCSIDevice *d, uint32_t tag, uint32_t lun, cmd.lba); } - if ((lun != d->lun && buf[0] != REQUEST_SENSE) || - buf[0] == REPORT_LUNS) { + if (lun != d->lun || + buf[0] == REPORT_LUNS || + buf[0] == REQUEST_SENSE) { req = scsi_req_alloc(&reqops_target_command, d, tag, lun, hba_private); } else { -- cgit v1.2.3-55-g7522