2 * QEMU Block driver for iSCSI images
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to deal
8 * in the Software without restriction, including without limitation the rights
9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 * copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25 #include "config-host.h"
28 #include <arpa/inet.h>
29 #include "qemu-common.h"
30 #include "qemu-error.h"
31 #include "block_int.h"
33 #include "hw/scsi-defs.h"
35 #include <iscsi/iscsi.h>
36 #include <iscsi/scsi-lowlevel.h>
40 #include <hw/scsi-defs.h>
43 typedef struct IscsiLun {
44 struct iscsi_context *iscsi;
46 enum scsi_inquiry_peripheral_device_type type;
52 typedef struct IscsiAIOCB {
53 BlockDriverAIOCB common;
57 struct scsi_task *task;
76 iscsi_abort_task_cb(struct iscsi_context *iscsi, int status, void *command_data,
82 iscsi_aio_cancel(BlockDriverAIOCB *blockacb)
84 IscsiAIOCB *acb = (IscsiAIOCB *)blockacb;
85 IscsiLun *iscsilun = acb->iscsilun;
87 acb->common.cb(acb->common.opaque, -ECANCELED);
90 /* send a task mgmt call to the target to cancel the task on the target */
91 iscsi_task_mgmt_abort_task_async(iscsilun->iscsi, acb->task,
92 iscsi_abort_task_cb, NULL);
94 /* then also cancel the task locally in libiscsi */
95 iscsi_scsi_task_cancel(iscsilun->iscsi, acb->task);
98 static AIOPool iscsi_aio_pool = {
99 .aiocb_size = sizeof(IscsiAIOCB),
100 .cancel = iscsi_aio_cancel,
104 static void iscsi_process_read(void *arg);
105 static void iscsi_process_write(void *arg);
107 static int iscsi_process_flush(void *arg)
109 IscsiLun *iscsilun = arg;
111 return iscsi_queue_length(iscsilun->iscsi) > 0;
115 iscsi_set_events(IscsiLun *iscsilun)
117 struct iscsi_context *iscsi = iscsilun->iscsi;
120 /* We always register a read handler. */
122 ev |= iscsi_which_events(iscsi);
123 if (ev != iscsilun->events) {
124 qemu_aio_set_fd_handler(iscsi_get_fd(iscsi),
126 (ev & POLLOUT) ? iscsi_process_write : NULL,
132 /* If we just added an event, the callback might be delayed
133 * unless we call qemu_notify_event().
135 if (ev & ~iscsilun->events) {
138 iscsilun->events = ev;
142 iscsi_process_read(void *arg)
144 IscsiLun *iscsilun = arg;
145 struct iscsi_context *iscsi = iscsilun->iscsi;
147 iscsi_service(iscsi, POLLIN);
148 iscsi_set_events(iscsilun);
152 iscsi_process_write(void *arg)
154 IscsiLun *iscsilun = arg;
155 struct iscsi_context *iscsi = iscsilun->iscsi;
157 iscsi_service(iscsi, POLLOUT);
158 iscsi_set_events(iscsilun);
163 iscsi_schedule_bh(QEMUBHFunc *cb, IscsiAIOCB *acb)
165 acb->bh = qemu_bh_new(cb, acb);
167 error_report("oom: could not create iscsi bh");
171 qemu_bh_schedule(acb->bh);
176 iscsi_readv_writev_bh_cb(void *p)
180 qemu_bh_delete(acb->bh);
182 if (acb->canceled == 0) {
183 acb->common.cb(acb->common.opaque, acb->status);
186 qemu_aio_release(acb);
191 iscsi_aio_write16_cb(struct iscsi_context *iscsi, int status,
192 void *command_data, void *opaque)
194 IscsiAIOCB *acb = opaque;
196 trace_iscsi_aio_write16_cb(iscsi, status, acb, acb->canceled);
200 if (acb->canceled != 0) {
201 qemu_aio_release(acb);
202 scsi_free_scsi_task(acb->task);
209 error_report("Failed to write16 data to iSCSI lun. %s",
210 iscsi_get_error(iscsi));
214 iscsi_schedule_bh(iscsi_readv_writev_bh_cb, acb);
215 scsi_free_scsi_task(acb->task);
219 static int64_t sector_qemu2lun(int64_t sector, IscsiLun *iscsilun)
221 return sector * BDRV_SECTOR_SIZE / iscsilun->block_size;
224 static BlockDriverAIOCB *
225 iscsi_aio_writev(BlockDriverState *bs, int64_t sector_num,
226 QEMUIOVector *qiov, int nb_sectors,
227 BlockDriverCompletionFunc *cb,
230 IscsiLun *iscsilun = bs->opaque;
231 struct iscsi_context *iscsi = iscsilun->iscsi;
234 uint32_t num_sectors;
236 struct iscsi_data data;
238 acb = qemu_aio_get(&iscsi_aio_pool, bs, cb, opaque);
239 trace_iscsi_aio_writev(iscsi, sector_num, nb_sectors, opaque, acb);
241 acb->iscsilun = iscsilun;
246 /* XXX we should pass the iovec to write16 to avoid the extra copy */
247 /* this will allow us to get rid of 'buf' completely */
248 size = nb_sectors * BDRV_SECTOR_SIZE;
249 acb->buf = g_malloc(size);
250 qemu_iovec_to_buf(acb->qiov, 0, acb->buf, size);
252 acb->task = malloc(sizeof(struct scsi_task));
253 if (acb->task == NULL) {
254 error_report("iSCSI: Failed to allocate task for scsi WRITE16 "
255 "command. %s", iscsi_get_error(iscsi));
256 qemu_aio_release(acb);
259 memset(acb->task, 0, sizeof(struct scsi_task));
261 acb->task->xfer_dir = SCSI_XFER_WRITE;
262 acb->task->cdb_size = 16;
263 acb->task->cdb[0] = 0x8a;
264 if (!(bs->open_flags & BDRV_O_CACHE_WB)) {
265 /* set FUA on writes when cache mode is write through */
266 acb->task->cdb[1] |= 0x04;
268 lba = sector_qemu2lun(sector_num, iscsilun);
269 *(uint32_t *)&acb->task->cdb[2] = htonl(lba >> 32);
270 *(uint32_t *)&acb->task->cdb[6] = htonl(lba & 0xffffffff);
271 num_sectors = size / iscsilun->block_size;
272 *(uint32_t *)&acb->task->cdb[10] = htonl(num_sectors);
273 acb->task->expxferlen = size;
275 data.data = acb->buf;
278 if (iscsi_scsi_command_async(iscsi, iscsilun->lun, acb->task,
279 iscsi_aio_write16_cb,
282 scsi_free_scsi_task(acb->task);
284 qemu_aio_release(acb);
288 iscsi_set_events(iscsilun);
294 iscsi_aio_read16_cb(struct iscsi_context *iscsi, int status,
295 void *command_data, void *opaque)
297 IscsiAIOCB *acb = opaque;
299 trace_iscsi_aio_read16_cb(iscsi, status, acb, acb->canceled);
301 if (acb->canceled != 0) {
302 qemu_aio_release(acb);
303 scsi_free_scsi_task(acb->task);
310 error_report("Failed to read16 data from iSCSI lun. %s",
311 iscsi_get_error(iscsi));
315 iscsi_schedule_bh(iscsi_readv_writev_bh_cb, acb);
316 scsi_free_scsi_task(acb->task);
320 static BlockDriverAIOCB *
321 iscsi_aio_readv(BlockDriverState *bs, int64_t sector_num,
322 QEMUIOVector *qiov, int nb_sectors,
323 BlockDriverCompletionFunc *cb,
326 IscsiLun *iscsilun = bs->opaque;
327 struct iscsi_context *iscsi = iscsilun->iscsi;
329 size_t qemu_read_size;
332 uint32_t num_sectors;
334 qemu_read_size = BDRV_SECTOR_SIZE * (size_t)nb_sectors;
336 acb = qemu_aio_get(&iscsi_aio_pool, bs, cb, opaque);
337 trace_iscsi_aio_readv(iscsi, sector_num, nb_sectors, opaque, acb);
339 acb->iscsilun = iscsilun;
343 acb->read_size = qemu_read_size;
346 /* If LUN blocksize is bigger than BDRV_BLOCK_SIZE a read from QEMU
347 * may be misaligned to the LUN, so we may need to read some extra
350 acb->read_offset = 0;
351 if (iscsilun->block_size > BDRV_SECTOR_SIZE) {
352 uint64_t bdrv_offset = BDRV_SECTOR_SIZE * sector_num;
354 acb->read_offset = bdrv_offset % iscsilun->block_size;
357 num_sectors = (qemu_read_size + iscsilun->block_size
358 + acb->read_offset - 1)
359 / iscsilun->block_size;
361 acb->task = malloc(sizeof(struct scsi_task));
362 if (acb->task == NULL) {
363 error_report("iSCSI: Failed to allocate task for scsi READ16 "
364 "command. %s", iscsi_get_error(iscsi));
365 qemu_aio_release(acb);
368 memset(acb->task, 0, sizeof(struct scsi_task));
370 acb->task->xfer_dir = SCSI_XFER_READ;
371 lba = sector_qemu2lun(sector_num, iscsilun);
372 acb->task->expxferlen = qemu_read_size;
374 switch (iscsilun->type) {
376 acb->task->cdb_size = 16;
377 acb->task->cdb[0] = 0x88;
378 *(uint32_t *)&acb->task->cdb[2] = htonl(lba >> 32);
379 *(uint32_t *)&acb->task->cdb[6] = htonl(lba & 0xffffffff);
380 *(uint32_t *)&acb->task->cdb[10] = htonl(num_sectors);
383 acb->task->cdb_size = 10;
384 acb->task->cdb[0] = 0x28;
385 *(uint32_t *)&acb->task->cdb[2] = htonl(lba);
386 *(uint16_t *)&acb->task->cdb[7] = htons(num_sectors);
390 if (iscsi_scsi_command_async(iscsi, iscsilun->lun, acb->task,
394 scsi_free_scsi_task(acb->task);
395 qemu_aio_release(acb);
399 for (i = 0; i < acb->qiov->niov; i++) {
400 scsi_task_add_data_in_buffer(acb->task,
401 acb->qiov->iov[i].iov_len,
402 acb->qiov->iov[i].iov_base);
405 iscsi_set_events(iscsilun);
412 iscsi_synccache10_cb(struct iscsi_context *iscsi, int status,
413 void *command_data, void *opaque)
415 IscsiAIOCB *acb = opaque;
417 if (acb->canceled != 0) {
418 qemu_aio_release(acb);
419 scsi_free_scsi_task(acb->task);
426 error_report("Failed to sync10 data on iSCSI lun. %s",
427 iscsi_get_error(iscsi));
431 iscsi_schedule_bh(iscsi_readv_writev_bh_cb, acb);
432 scsi_free_scsi_task(acb->task);
436 static BlockDriverAIOCB *
437 iscsi_aio_flush(BlockDriverState *bs,
438 BlockDriverCompletionFunc *cb, void *opaque)
440 IscsiLun *iscsilun = bs->opaque;
441 struct iscsi_context *iscsi = iscsilun->iscsi;
444 acb = qemu_aio_get(&iscsi_aio_pool, bs, cb, opaque);
446 acb->iscsilun = iscsilun;
449 acb->task = iscsi_synchronizecache10_task(iscsi, iscsilun->lun,
451 iscsi_synccache10_cb,
453 if (acb->task == NULL) {
454 error_report("iSCSI: Failed to send synchronizecache10 command. %s",
455 iscsi_get_error(iscsi));
456 qemu_aio_release(acb);
460 iscsi_set_events(iscsilun);
466 iscsi_unmap_cb(struct iscsi_context *iscsi, int status,
467 void *command_data, void *opaque)
469 IscsiAIOCB *acb = opaque;
471 if (acb->canceled != 0) {
472 qemu_aio_release(acb);
473 scsi_free_scsi_task(acb->task);
480 error_report("Failed to unmap data on iSCSI lun. %s",
481 iscsi_get_error(iscsi));
485 iscsi_schedule_bh(iscsi_readv_writev_bh_cb, acb);
486 scsi_free_scsi_task(acb->task);
490 static BlockDriverAIOCB *
491 iscsi_aio_discard(BlockDriverState *bs,
492 int64_t sector_num, int nb_sectors,
493 BlockDriverCompletionFunc *cb, void *opaque)
495 IscsiLun *iscsilun = bs->opaque;
496 struct iscsi_context *iscsi = iscsilun->iscsi;
498 struct unmap_list list[1];
500 acb = qemu_aio_get(&iscsi_aio_pool, bs, cb, opaque);
502 acb->iscsilun = iscsilun;
505 list[0].lba = sector_qemu2lun(sector_num, iscsilun);
506 list[0].num = nb_sectors * BDRV_SECTOR_SIZE / iscsilun->block_size;
508 acb->task = iscsi_unmap_task(iscsi, iscsilun->lun,
512 if (acb->task == NULL) {
513 error_report("iSCSI: Failed to send unmap command. %s",
514 iscsi_get_error(iscsi));
515 qemu_aio_release(acb);
519 iscsi_set_events(iscsilun);
526 iscsi_aio_ioctl_cb(struct iscsi_context *iscsi, int status,
527 void *command_data, void *opaque)
529 IscsiAIOCB *acb = opaque;
531 if (acb->canceled != 0) {
532 qemu_aio_release(acb);
533 scsi_free_scsi_task(acb->task);
540 error_report("Failed to ioctl(SG_IO) to iSCSI lun. %s",
541 iscsi_get_error(iscsi));
545 acb->ioh->driver_status = 0;
546 acb->ioh->host_status = 0;
549 #define SG_ERR_DRIVER_SENSE 0x08
551 if (status == SCSI_STATUS_CHECK_CONDITION && acb->task->datain.size >= 2) {
554 acb->ioh->driver_status |= SG_ERR_DRIVER_SENSE;
556 acb->ioh->sb_len_wr = acb->task->datain.size - 2;
557 ss = (acb->ioh->mx_sb_len >= acb->ioh->sb_len_wr) ?
558 acb->ioh->mx_sb_len : acb->ioh->sb_len_wr;
559 memcpy(acb->ioh->sbp, &acb->task->datain.data[2], ss);
562 iscsi_schedule_bh(iscsi_readv_writev_bh_cb, acb);
563 scsi_free_scsi_task(acb->task);
567 static BlockDriverAIOCB *iscsi_aio_ioctl(BlockDriverState *bs,
568 unsigned long int req, void *buf,
569 BlockDriverCompletionFunc *cb, void *opaque)
571 IscsiLun *iscsilun = bs->opaque;
572 struct iscsi_context *iscsi = iscsilun->iscsi;
573 struct iscsi_data data;
576 assert(req == SG_IO);
578 acb = qemu_aio_get(&iscsi_aio_pool, bs, cb, opaque);
580 acb->iscsilun = iscsilun;
585 acb->task = malloc(sizeof(struct scsi_task));
586 if (acb->task == NULL) {
587 error_report("iSCSI: Failed to allocate task for scsi command. %s",
588 iscsi_get_error(iscsi));
589 qemu_aio_release(acb);
592 memset(acb->task, 0, sizeof(struct scsi_task));
594 switch (acb->ioh->dxfer_direction) {
595 case SG_DXFER_TO_DEV:
596 acb->task->xfer_dir = SCSI_XFER_WRITE;
598 case SG_DXFER_FROM_DEV:
599 acb->task->xfer_dir = SCSI_XFER_READ;
602 acb->task->xfer_dir = SCSI_XFER_NONE;
606 acb->task->cdb_size = acb->ioh->cmd_len;
607 memcpy(&acb->task->cdb[0], acb->ioh->cmdp, acb->ioh->cmd_len);
608 acb->task->expxferlen = acb->ioh->dxfer_len;
610 if (acb->task->xfer_dir == SCSI_XFER_WRITE) {
611 data.data = acb->ioh->dxferp;
612 data.size = acb->ioh->dxfer_len;
614 if (iscsi_scsi_command_async(iscsi, iscsilun->lun, acb->task,
616 (acb->task->xfer_dir == SCSI_XFER_WRITE) ?
619 scsi_free_scsi_task(acb->task);
620 qemu_aio_release(acb);
624 /* tell libiscsi to read straight into the buffer we got from ioctl */
625 if (acb->task->xfer_dir == SCSI_XFER_READ) {
626 scsi_task_add_data_in_buffer(acb->task,
631 iscsi_set_events(iscsilun);
636 static int iscsi_ioctl(BlockDriverState *bs, unsigned long int req, void *buf)
638 IscsiLun *iscsilun = bs->opaque;
641 case SG_GET_VERSION_NUM:
645 ((struct sg_scsi_id *)buf)->scsi_type = iscsilun->type;
655 iscsi_getlength(BlockDriverState *bs)
657 IscsiLun *iscsilun = bs->opaque;
660 len = iscsilun->num_blocks;
661 len *= iscsilun->block_size;
667 iscsi_readcapacity16_cb(struct iscsi_context *iscsi, int status,
668 void *command_data, void *opaque)
670 struct IscsiTask *itask = opaque;
671 struct scsi_readcapacity16 *rc16;
672 struct scsi_task *task = command_data;
675 error_report("iSCSI: Failed to read capacity of iSCSI lun. %s",
676 iscsi_get_error(iscsi));
679 scsi_free_scsi_task(task);
683 rc16 = scsi_datain_unmarshall(task);
685 error_report("iSCSI: Failed to unmarshall readcapacity16 data.");
688 scsi_free_scsi_task(task);
692 itask->iscsilun->block_size = rc16->block_length;
693 itask->iscsilun->num_blocks = rc16->returned_lba + 1;
694 itask->bs->total_sectors = itask->iscsilun->num_blocks *
695 itask->iscsilun->block_size / BDRV_SECTOR_SIZE ;
699 scsi_free_scsi_task(task);
703 iscsi_readcapacity10_cb(struct iscsi_context *iscsi, int status,
704 void *command_data, void *opaque)
706 struct IscsiTask *itask = opaque;
707 struct scsi_readcapacity10 *rc10;
708 struct scsi_task *task = command_data;
711 error_report("iSCSI: Failed to read capacity of iSCSI lun. %s",
712 iscsi_get_error(iscsi));
715 scsi_free_scsi_task(task);
719 rc10 = scsi_datain_unmarshall(task);
721 error_report("iSCSI: Failed to unmarshall readcapacity10 data.");
724 scsi_free_scsi_task(task);
728 itask->iscsilun->block_size = rc10->block_size;
729 itask->iscsilun->num_blocks = rc10->lba + 1;
730 itask->bs->total_sectors = itask->iscsilun->num_blocks *
731 itask->iscsilun->block_size / BDRV_SECTOR_SIZE ;
735 scsi_free_scsi_task(task);
739 iscsi_inquiry_cb(struct iscsi_context *iscsi, int status, void *command_data,
742 struct IscsiTask *itask = opaque;
743 struct scsi_task *task = command_data;
744 struct scsi_inquiry_standard *inq;
749 scsi_free_scsi_task(task);
753 inq = scsi_datain_unmarshall(task);
755 error_report("iSCSI: Failed to unmarshall inquiry data.");
758 scsi_free_scsi_task(task);
762 itask->iscsilun->type = inq->periperal_device_type;
764 scsi_free_scsi_task(task);
766 switch (itask->iscsilun->type) {
768 task = iscsi_readcapacity16_task(iscsi, itask->iscsilun->lun,
769 iscsi_readcapacity16_cb, opaque);
771 error_report("iSCSI: failed to send readcapacity16 command.");
778 task = iscsi_readcapacity10_task(iscsi, itask->iscsilun->lun,
780 iscsi_readcapacity10_cb, opaque);
782 error_report("iSCSI: failed to send readcapacity16 command.");
795 iscsi_connect_cb(struct iscsi_context *iscsi, int status, void *command_data,
798 struct IscsiTask *itask = opaque;
799 struct scsi_task *task;
807 task = iscsi_inquiry_task(iscsi, itask->iscsilun->lun,
809 iscsi_inquiry_cb, opaque);
811 error_report("iSCSI: failed to send inquiry command.");
818 static int parse_chap(struct iscsi_context *iscsi, const char *target)
822 const char *user = NULL;
823 const char *password = NULL;
825 list = qemu_find_opts("iscsi");
830 opts = qemu_opts_find(list, target);
832 opts = QTAILQ_FIRST(&list->head);
838 user = qemu_opt_get(opts, "user");
843 password = qemu_opt_get(opts, "password");
845 error_report("CHAP username specified but no password was given");
849 if (iscsi_set_initiator_username_pwd(iscsi, user, password)) {
850 error_report("Failed to set initiator username and password");
857 static void parse_header_digest(struct iscsi_context *iscsi, const char *target)
861 const char *digest = NULL;
863 list = qemu_find_opts("iscsi");
868 opts = qemu_opts_find(list, target);
870 opts = QTAILQ_FIRST(&list->head);
876 digest = qemu_opt_get(opts, "header-digest");
881 if (!strcmp(digest, "CRC32C")) {
882 iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_CRC32C);
883 } else if (!strcmp(digest, "NONE")) {
884 iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_NONE);
885 } else if (!strcmp(digest, "CRC32C-NONE")) {
886 iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_CRC32C_NONE);
887 } else if (!strcmp(digest, "NONE-CRC32C")) {
888 iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_NONE_CRC32C);
890 error_report("Invalid header-digest setting : %s", digest);
894 static char *parse_initiator_name(const char *target)
898 const char *name = NULL;
899 const char *iscsi_name = qemu_get_vm_name();
901 list = qemu_find_opts("iscsi");
903 opts = qemu_opts_find(list, target);
905 opts = QTAILQ_FIRST(&list->head);
908 name = qemu_opt_get(opts, "initiator-name");
913 return g_strdup(name);
915 return g_strdup_printf("iqn.2008-11.org.linux-kvm%s%s",
916 iscsi_name ? ":" : "",
917 iscsi_name ? iscsi_name : "");
922 * We support iscsi url's on the form
923 * iscsi://[<username>%<password>@]<host>[:<port>]/<targetname>/<lun>
925 static int iscsi_open(BlockDriverState *bs, const char *filename, int flags)
927 IscsiLun *iscsilun = bs->opaque;
928 struct iscsi_context *iscsi = NULL;
929 struct iscsi_url *iscsi_url = NULL;
930 struct IscsiTask task;
931 char *initiator_name = NULL;
934 if ((BDRV_SECTOR_SIZE % 512) != 0) {
935 error_report("iSCSI: Invalid BDRV_SECTOR_SIZE. "
936 "BDRV_SECTOR_SIZE(%lld) is not a multiple "
937 "of 512", BDRV_SECTOR_SIZE);
941 iscsi_url = iscsi_parse_full_url(iscsi, filename);
942 if (iscsi_url == NULL) {
943 error_report("Failed to parse URL : %s %s", filename,
944 iscsi_get_error(iscsi));
949 memset(iscsilun, 0, sizeof(IscsiLun));
951 initiator_name = parse_initiator_name(iscsi_url->target);
953 iscsi = iscsi_create_context(initiator_name);
955 error_report("iSCSI: Failed to create iSCSI context.");
960 if (iscsi_set_targetname(iscsi, iscsi_url->target)) {
961 error_report("iSCSI: Failed to set target name.");
966 if (iscsi_url->user != NULL) {
967 ret = iscsi_set_initiator_username_pwd(iscsi, iscsi_url->user,
970 error_report("Failed to set initiator username and password");
976 /* check if we got CHAP username/password via the options */
977 if (parse_chap(iscsi, iscsi_url->target) != 0) {
978 error_report("iSCSI: Failed to set CHAP user/password");
983 if (iscsi_set_session_type(iscsi, ISCSI_SESSION_NORMAL) != 0) {
984 error_report("iSCSI: Failed to set session type to normal.");
989 iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_NONE_CRC32C);
991 /* check if we got HEADER_DIGEST via the options */
992 parse_header_digest(iscsi, iscsi_url->target);
994 task.iscsilun = iscsilun;
999 iscsilun->iscsi = iscsi;
1000 iscsilun->lun = iscsi_url->lun;
1002 if (iscsi_full_connect_async(iscsi, iscsi_url->portal, iscsi_url->lun,
1003 iscsi_connect_cb, &task)
1005 error_report("iSCSI: Failed to start async connect.");
1010 while (!task.complete) {
1011 iscsi_set_events(iscsilun);
1014 if (task.status != 0) {
1015 error_report("iSCSI: Failed to connect to LUN : %s",
1016 iscsi_get_error(iscsi));
1021 /* Medium changer or tape. We dont have any emulation for this so this must
1022 * be sg ioctl compatible. We force it to be sg, otherwise qemu will try
1023 * to read from the device to guess the image format.
1025 if (iscsilun->type == TYPE_MEDIUM_CHANGER ||
1026 iscsilun->type == TYPE_TAPE) {
1033 if (initiator_name != NULL) {
1034 g_free(initiator_name);
1036 if (iscsi_url != NULL) {
1037 iscsi_destroy_url(iscsi_url);
1041 if (iscsi != NULL) {
1042 iscsi_destroy_context(iscsi);
1044 memset(iscsilun, 0, sizeof(IscsiLun));
1049 static void iscsi_close(BlockDriverState *bs)
1051 IscsiLun *iscsilun = bs->opaque;
1052 struct iscsi_context *iscsi = iscsilun->iscsi;
1054 qemu_aio_set_fd_handler(iscsi_get_fd(iscsi), NULL, NULL, NULL, NULL);
1055 iscsi_destroy_context(iscsi);
1056 memset(iscsilun, 0, sizeof(IscsiLun));
1059 static BlockDriver bdrv_iscsi = {
1060 .format_name = "iscsi",
1061 .protocol_name = "iscsi",
1063 .instance_size = sizeof(IscsiLun),
1064 .bdrv_file_open = iscsi_open,
1065 .bdrv_close = iscsi_close,
1067 .bdrv_getlength = iscsi_getlength,
1069 .bdrv_aio_readv = iscsi_aio_readv,
1070 .bdrv_aio_writev = iscsi_aio_writev,
1071 .bdrv_aio_flush = iscsi_aio_flush,
1073 .bdrv_aio_discard = iscsi_aio_discard,
1076 .bdrv_ioctl = iscsi_ioctl,
1077 .bdrv_aio_ioctl = iscsi_aio_ioctl,
1081 static void iscsi_block_init(void)
1083 bdrv_register(&bdrv_iscsi);
1086 block_init(iscsi_block_init);