14
#include "qemu/osdep.h"
15
#include "qapi/error.h"
16
#include "qemu/ctype.h"
17
#include "qemu/error-report.h"
18
#include "qemu/module.h"
19
#include "hw/scsi/scsi.h"
20
#include "migration/qemu-file-types.h"
21
#include "hw/qdev-properties.h"
22
#include "hw/qdev-properties-system.h"
23
#include "hw/scsi/emulation.h"
24
#include "sysemu/block-backend.h"
30
#include "scsi/constants.h"
33
#define MAX_UINT ((unsigned int)-1)
36
typedef struct SCSIGenericReq {
41
sg_io_hdr_t io_header;
44
static void scsi_generic_save_request(QEMUFile *f, SCSIRequest *req)
46
SCSIGenericReq *r = DO_UPCAST(SCSIGenericReq, req, req);
48
qemu_put_sbe32s(f, &r->buflen);
49
if (r->buflen && r->req.cmd.mode == SCSI_XFER_TO_DEV) {
51
qemu_put_buffer(f, r->buf, r->req.cmd.xfer);
55
static void scsi_generic_load_request(QEMUFile *f, SCSIRequest *req)
57
SCSIGenericReq *r = DO_UPCAST(SCSIGenericReq, req, req);
59
qemu_get_sbe32s(f, &r->buflen);
60
if (r->buflen && r->req.cmd.mode == SCSI_XFER_TO_DEV) {
62
qemu_get_buffer(f, r->buf, r->req.cmd.xfer);
66
static void scsi_free_request(SCSIRequest *req)
68
SCSIGenericReq *r = DO_UPCAST(SCSIGenericReq, req, req);
74
static void scsi_command_complete_noio(SCSIGenericReq *r, int ret)
78
sg_io_hdr_t *io_hdr = &r->io_header;
80
assert(r->req.aiocb == NULL);
82
if (r->req.io_canceled) {
83
scsi_req_cancel_complete(&r->req);
87
status = scsi_sense_from_errno(-ret, &sense);
88
if (status == CHECK_CONDITION) {
89
scsi_req_build_sense(&r->req, sense);
91
} else if (io_hdr->host_status != SCSI_HOST_OK) {
92
scsi_req_complete_failed(&r->req, io_hdr->host_status);
94
} else if (io_hdr->driver_status & SG_ERR_DRIVER_TIMEOUT) {
97
status = io_hdr->status;
98
if (io_hdr->driver_status & SG_ERR_DRIVER_SENSE) {
99
r->req.sense_len = io_hdr->sb_len_wr;
102
trace_scsi_generic_command_complete_noio(r, r->req.tag, status);
104
scsi_req_complete(&r->req, status);
106
scsi_req_unref(&r->req);
109
static void scsi_command_complete(void *opaque, int ret)
111
SCSIGenericReq *r = (SCSIGenericReq *)opaque;
113
assert(r->req.aiocb != NULL);
116
scsi_command_complete_noio(r, ret);
119
static int execute_command(BlockBackend *blk,
120
SCSIGenericReq *r, int direction,
121
BlockCompletionFunc *complete)
123
SCSIDevice *s = r->req.dev;
125
r->io_header.interface_id = 'S';
126
r->io_header.dxfer_direction = direction;
127
r->io_header.dxferp = r->buf;
128
r->io_header.dxfer_len = r->buflen;
129
r->io_header.cmdp = r->req.cmd.buf;
130
r->io_header.cmd_len = r->req.cmd.len;
131
r->io_header.mx_sb_len = sizeof(r->req.sense);
132
r->io_header.sbp = r->req.sense;
133
r->io_header.timeout = s->io_timeout * 1000;
134
r->io_header.usr_ptr = r;
135
r->io_header.flags |= SG_FLAG_DIRECT_IO;
137
trace_scsi_generic_aio_sgio_command(r->req.tag, r->req.cmd.buf[0],
138
r->io_header.timeout);
139
r->req.aiocb = blk_aio_ioctl(blk, SG_IO, &r->io_header, complete, r);
140
if (r->req.aiocb == NULL) {
147
static uint64_t calculate_max_transfer(SCSIDevice *s)
149
uint64_t max_transfer = blk_get_max_hw_transfer(s->conf.blk);
150
uint32_t max_iov = blk_get_max_hw_iov(s->conf.blk);
152
assert(max_transfer);
153
max_transfer = MIN_NON_ZERO(max_transfer,
154
max_iov * qemu_real_host_page_size());
156
return max_transfer / s->blocksize;
159
static int scsi_handle_inquiry_reply(SCSIGenericReq *r, SCSIDevice *s, int len)
161
uint8_t page, page_idx;
180
if (s->scsi_version == -1 && !(r->req.cmd.buf[1] & 0x01)) {
181
s->scsi_version = r->buf[2] & 0x07;
182
if (s->scsi_version > 2) {
183
s->scsi_version = r->buf[2];
187
if ((s->type == TYPE_DISK || s->type == TYPE_ZBC) &&
188
(r->req.cmd.buf[1] & 0x01)) {
189
page = r->req.cmd.buf[2];
190
if (page == 0xb0 && r->buflen >= 8) {
191
uint8_t buf[16] = {};
192
uint8_t buf_used = MIN(r->buflen, 16);
193
uint64_t max_transfer = calculate_max_transfer(s);
195
memcpy(buf, r->buf, buf_used);
196
stl_be_p(&buf[8], max_transfer);
197
stl_be_p(&buf[12], MIN_NON_ZERO(max_transfer, ldl_be_p(&buf[12])));
198
memcpy(r->buf + 8, buf + 8, buf_used - 8);
200
} else if (s->needs_vpd_bl_emulation && page == 0x00 && r->buflen >= 4) {
214
page_idx = lduw_be_p(r->buf + 2) + 4;
215
page_idx = MIN(page_idx, r->buflen);
216
while (page_idx > 4 && r->buf[page_idx - 1] >= 0xb0) {
217
if (page_idx < r->buflen) {
218
r->buf[page_idx] = r->buf[page_idx - 1];
222
if (page_idx < r->buflen) {
223
r->buf[page_idx] = 0xb0;
225
stw_be_p(r->buf + 2, lduw_be_p(r->buf + 2) + 1);
227
if (len < r->buflen) {
235
static int scsi_generic_emulate_block_limits(SCSIGenericReq *r, SCSIDevice *s)
240
SCSIBlockLimits bl = {
241
.max_io_sectors = calculate_max_transfer(s),
244
memset(r->buf, 0, r->buflen);
246
stb_p(buf + 1, 0xb0);
247
len = scsi_emulate_block_limits(buf + 4, &bl);
248
assert(len <= sizeof(buf) - 4);
249
stw_be_p(buf + 2, len);
251
memcpy(r->buf, buf, MIN(r->buflen, len + 4));
253
r->io_header.sb_len_wr = 0;
261
r->io_header.driver_status = 0;
262
r->io_header.status = 0;
267
static void scsi_read_complete(void * opaque, int ret)
269
SCSIGenericReq *r = (SCSIGenericReq *)opaque;
270
SCSIDevice *s = r->req.dev;
273
assert(r->req.aiocb != NULL);
276
if (ret || r->req.io_canceled) {
277
scsi_command_complete_noio(r, ret);
281
len = r->io_header.dxfer_len - r->io_header.resid;
282
trace_scsi_generic_read_complete(r->req.tag, len);
286
if (r->io_header.driver_status & SG_ERR_DRIVER_SENSE) {
288
scsi_parse_sense_buf(r->req.sense, r->io_header.sb_len_wr);
295
if (sense.key == ILLEGAL_REQUEST &&
296
s->needs_vpd_bl_emulation &&
297
r->req.cmd.buf[0] == INQUIRY &&
298
(r->req.cmd.buf[1] & 0x01) &&
299
r->req.cmd.buf[2] == 0xb0) {
300
len = scsi_generic_emulate_block_limits(r, s);
312
if (r->io_header.host_status != SCSI_HOST_OK ||
313
(r->io_header.driver_status & SG_ERR_DRIVER_TIMEOUT) ||
314
r->io_header.status != GOOD ||
316
scsi_command_complete_noio(r, 0);
321
if (r->req.cmd.buf[0] == READ_CAPACITY_10 &&
322
(ldl_be_p(&r->buf[0]) != 0xffffffffU || s->max_lba == 0)) {
323
s->blocksize = ldl_be_p(&r->buf[4]);
324
s->max_lba = ldl_be_p(&r->buf[0]) & 0xffffffffULL;
325
} else if (r->req.cmd.buf[0] == SERVICE_ACTION_IN_16 &&
326
(r->req.cmd.buf[1] & 31) == SAI_READ_CAPACITY_16) {
327
s->blocksize = ldl_be_p(&r->buf[8]);
328
s->max_lba = ldq_be_p(&r->buf[0]);
335
if ((s->type == TYPE_DISK || s->type == TYPE_TAPE || s->type == TYPE_ZBC) &&
336
!blk_is_writable(s->conf.blk) &&
337
(r->req.cmd.buf[0] == MODE_SENSE ||
338
r->req.cmd.buf[0] == MODE_SENSE_10) &&
339
(r->req.cmd.buf[1] & 0x8) == 0) {
340
if (r->req.cmd.buf[0] == MODE_SENSE) {
346
if (r->req.cmd.buf[0] == INQUIRY) {
347
len = scsi_handle_inquiry_reply(r, s, len);
351
scsi_req_data(&r->req, len);
352
scsi_req_unref(&r->req);
356
static void scsi_read_data(SCSIRequest *req)
358
SCSIGenericReq *r = DO_UPCAST(SCSIGenericReq, req, req);
359
SCSIDevice *s = r->req.dev;
362
trace_scsi_generic_read_data(req->tag);
365
scsi_req_ref(&r->req);
367
scsi_command_complete_noio(r, 0);
371
ret = execute_command(s->conf.blk, r, SG_DXFER_FROM_DEV,
374
scsi_command_complete_noio(r, ret);
378
static void scsi_write_complete(void * opaque, int ret)
380
SCSIGenericReq *r = (SCSIGenericReq *)opaque;
381
SCSIDevice *s = r->req.dev;
383
trace_scsi_generic_write_complete(ret);
385
assert(r->req.aiocb != NULL);
388
if (ret || r->req.io_canceled) {
389
scsi_command_complete_noio(r, ret);
393
if (r->req.cmd.buf[0] == MODE_SELECT && r->req.cmd.buf[4] == 12 &&
394
s->type == TYPE_TAPE) {
395
s->blocksize = (r->buf[9] << 16) | (r->buf[10] << 8) | r->buf[11];
396
trace_scsi_generic_write_complete_blocksize(s->blocksize);
399
scsi_command_complete_noio(r, ret);
404
static void scsi_write_data(SCSIRequest *req)
406
SCSIGenericReq *r = DO_UPCAST(SCSIGenericReq, req, req);
407
SCSIDevice *s = r->req.dev;
410
trace_scsi_generic_write_data(req->tag);
413
scsi_req_data(&r->req, r->len);
418
scsi_req_ref(&r->req);
419
ret = execute_command(s->conf.blk, r, SG_DXFER_TO_DEV, scsi_write_complete);
421
scsi_command_complete_noio(r, ret);
426
static uint8_t *scsi_get_buf(SCSIRequest *req)
428
SCSIGenericReq *r = DO_UPCAST(SCSIGenericReq, req, req);
433
static void scsi_generic_command_dump(uint8_t *cmd, int len)
436
char *line_buffer, *p;
438
line_buffer = g_malloc(len * 5 + 1);
440
for (i = 0, p = line_buffer; i < len; i++) {
441
p += sprintf(p, " 0x%02x", cmd[i]);
443
trace_scsi_generic_send_command(line_buffer);
453
static int32_t scsi_send_command(SCSIRequest *req, uint8_t *cmd)
455
SCSIGenericReq *r = DO_UPCAST(SCSIGenericReq, req, req);
456
SCSIDevice *s = r->req.dev;
459
if (trace_event_get_state_backends(TRACE_SCSI_GENERIC_SEND_COMMAND)) {
460
scsi_generic_command_dump(cmd, r->req.cmd.len);
463
if (r->req.cmd.xfer == 0) {
468
scsi_req_ref(&r->req);
469
ret = execute_command(s->conf.blk, r, SG_DXFER_NONE,
470
scsi_command_complete);
472
scsi_command_complete_noio(r, ret);
478
if (r->buflen != r->req.cmd.xfer) {
480
r->buf = g_malloc(r->req.cmd.xfer);
481
r->buflen = r->req.cmd.xfer;
484
memset(r->buf, 0, r->buflen);
485
r->len = r->req.cmd.xfer;
486
if (r->req.cmd.mode == SCSI_XFER_TO_DEV) {
488
return -r->req.cmd.xfer;
490
return r->req.cmd.xfer;
494
static int read_naa_id(const uint8_t *p, uint64_t *p_wwn)
498
if ((p[1] & 0xF) == 3) {
503
*p_wwn = ldq_be_p(p + 4);
507
if ((p[1] & 0xF) == 8) {
509
if (p[3] < 20 || memcmp(&p[4], "naa.", 4)) {
512
if (p[3] > 20 && p[24] != ',') {
516
for (i = 8; i < 24; i++) {
517
char c = qemu_toupper(p[i]);
518
c -= (c >= '0' && c <= '9' ? '0' : 'A' - 10);
519
*p_wwn = (*p_wwn << 4) | c;
527
int scsi_SG_IO_FROM_DEV(BlockBackend *blk, uint8_t *cmd, uint8_t cmd_size,
528
uint8_t *buf, uint8_t buf_size, uint32_t timeout)
530
sg_io_hdr_t io_header;
534
memset(&io_header, 0, sizeof(io_header));
535
io_header.interface_id = 'S';
536
io_header.dxfer_direction = SG_DXFER_FROM_DEV;
537
io_header.dxfer_len = buf_size;
538
io_header.dxferp = buf;
539
io_header.cmdp = cmd;
540
io_header.cmd_len = cmd_size;
541
io_header.mx_sb_len = sizeof(sensebuf);
542
io_header.sbp = sensebuf;
543
io_header.timeout = timeout * 1000;
545
trace_scsi_generic_ioctl_sgio_command(cmd[0], io_header.timeout);
546
ret = blk_ioctl(blk, SG_IO, &io_header);
547
if (ret < 0 || io_header.status ||
548
io_header.driver_status || io_header.host_status) {
549
trace_scsi_generic_ioctl_sgio_done(cmd[0], ret, io_header.status,
550
io_header.host_status);
562
static void scsi_generic_set_vpd_bl_emulation(SCSIDevice *s)
569
memset(cmd, 0, sizeof(cmd));
570
memset(buf, 0, sizeof(buf));
574
cmd[4] = sizeof(buf);
576
ret = scsi_SG_IO_FROM_DEV(s->conf.blk, cmd, sizeof(cmd),
577
buf, sizeof(buf), s->io_timeout);
584
s->needs_vpd_bl_emulation = false;
589
for (i = 4; i < MIN(sizeof(buf), page_len + 4); i++) {
590
if (buf[i] == 0xb0) {
591
s->needs_vpd_bl_emulation = false;
595
s->needs_vpd_bl_emulation = true;
598
static void scsi_generic_read_device_identification(SCSIDevice *s)
605
memset(cmd, 0, sizeof(cmd));
606
memset(buf, 0, sizeof(buf));
610
cmd[4] = sizeof(buf);
612
ret = scsi_SG_IO_FROM_DEV(s->conf.blk, cmd, sizeof(cmd),
613
buf, sizeof(buf), s->io_timeout);
618
len = MIN((buf[2] << 8) | buf[3], sizeof(buf) - 4);
619
for (i = 0; i + 3 <= len; ) {
620
const uint8_t *p = &buf[i + 4];
623
if (i + (p[3] + 4) > len) {
627
if ((p[1] & 0x10) == 0) {
629
if (read_naa_id(p, &wwn) == 0) {
632
} else if ((p[1] & 0x10) == 0x10) {
634
if (read_naa_id(p, &wwn) == 0) {
643
void scsi_generic_read_device_inquiry(SCSIDevice *s)
645
scsi_generic_read_device_identification(s);
646
if (s->type == TYPE_DISK || s->type == TYPE_ZBC) {
647
scsi_generic_set_vpd_bl_emulation(s);
649
s->needs_vpd_bl_emulation = false;
653
static int get_stream_blocksize(BlockBackend *blk)
659
memset(cmd, 0, sizeof(cmd));
660
memset(buf, 0, sizeof(buf));
662
cmd[4] = sizeof(buf);
664
ret = scsi_SG_IO_FROM_DEV(blk, cmd, sizeof(cmd), buf, sizeof(buf), 6);
669
return (buf[9] << 16) | (buf[10] << 8) | buf[11];
672
static void scsi_generic_reset(DeviceState *dev)
674
SCSIDevice *s = SCSI_DEVICE(dev);
676
s->scsi_version = s->default_scsi_version;
677
scsi_device_purge_requests(s, SENSE_CODE(RESET));
680
static void scsi_generic_realize(SCSIDevice *s, Error **errp)
684
struct sg_scsi_id scsiid;
687
error_setg(errp, "drive property not set");
691
if (blk_get_on_error(s->conf.blk, 0) != BLOCKDEV_ON_ERROR_ENOSPC &&
692
blk_get_on_error(s->conf.blk, 0) != BLOCKDEV_ON_ERROR_REPORT) {
693
error_setg(errp, "Device doesn't support drive option werror");
696
if (blk_get_on_error(s->conf.blk, 1) != BLOCKDEV_ON_ERROR_REPORT) {
697
error_setg(errp, "Device doesn't support drive option rerror");
702
rc = blk_ioctl(s->conf.blk, SG_GET_VERSION_NUM, &sg_version);
704
error_setg_errno(errp, -rc, "cannot get SG_IO version number");
706
error_append_hint(errp, "Is this a SCSI device?\n");
710
if (sg_version < 30000) {
711
error_setg(errp, "scsi generic interface too old");
716
if (blk_ioctl(s->conf.blk, SG_GET_SCSI_ID, &scsiid)) {
717
error_setg(errp, "SG_GET_SCSI_ID ioctl failed");
720
if (!blkconf_apply_backend_options(&s->conf,
721
!blk_supports_write_perm(s->conf.blk),
727
s->type = scsiid.scsi_type;
728
trace_scsi_generic_realize_type(s->type);
732
s->blocksize = get_stream_blocksize(s->conf.blk);
733
if (s->blocksize == -1) {
751
trace_scsi_generic_realize_blocksize(s->blocksize);
754
s->default_scsi_version = -1;
755
scsi_generic_read_device_inquiry(s);
758
const SCSIReqOps scsi_generic_req_ops = {
759
.size = sizeof(SCSIGenericReq),
760
.free_req = scsi_free_request,
761
.send_command = scsi_send_command,
762
.read_data = scsi_read_data,
763
.write_data = scsi_write_data,
764
.get_buf = scsi_get_buf,
765
.load_request = scsi_generic_load_request,
766
.save_request = scsi_generic_save_request,
769
static SCSIRequest *scsi_new_request(SCSIDevice *d, uint32_t tag, uint32_t lun,
770
uint8_t *buf, void *hba_private)
772
return scsi_req_alloc(&scsi_generic_req_ops, d, tag, lun, hba_private);
775
static Property scsi_generic_properties[] = {
776
DEFINE_PROP_DRIVE("drive", SCSIDevice, conf.blk),
777
DEFINE_PROP_BOOL("share-rw", SCSIDevice, conf.share_rw, false),
778
DEFINE_PROP_UINT32("io_timeout", SCSIDevice, io_timeout,
780
DEFINE_PROP_END_OF_LIST(),
783
static int scsi_generic_parse_cdb(SCSIDevice *dev, SCSICommand *cmd,
784
uint8_t *buf, size_t buf_len,
787
return scsi_bus_parse_cdb(dev, cmd, buf, buf_len, hba_private);
790
static void scsi_generic_class_initfn(ObjectClass *klass, void *data)
792
DeviceClass *dc = DEVICE_CLASS(klass);
793
SCSIDeviceClass *sc = SCSI_DEVICE_CLASS(klass);
795
sc->realize = scsi_generic_realize;
796
sc->alloc_req = scsi_new_request;
797
sc->parse_cdb = scsi_generic_parse_cdb;
798
dc->fw_name = "disk";
799
dc->desc = "pass through generic scsi device (/dev/sg*)";
800
dc->reset = scsi_generic_reset;
801
device_class_set_props(dc, scsi_generic_properties);
802
dc->vmsd = &vmstate_scsi_device;
805
static const TypeInfo scsi_generic_info = {
806
.name = "scsi-generic",
807
.parent = TYPE_SCSI_DEVICE,
808
.instance_size = sizeof(SCSIDevice),
809
.class_init = scsi_generic_class_initfn,
812
static void scsi_generic_register_types(void)
814
type_register_static(&scsi_generic_info);
817
type_init(scsi_generic_register_types)