scsi-disk: restruct emulation: GET_CONFIGURATION
authorGerd Hoffmann <kraxel@redhat.com>
Thu, 26 Nov 2009 14:34:12 +0000 (15:34 +0100)
committerAnthony Liguori <aliguori@us.ibm.com>
Thu, 3 Dec 2009 15:41:40 +0000 (09:41 -0600)
Move GET_CONFIGURATION emulation from scsi_send_command() to
scsi_disk_emulate_command().

Also add GET_CONFIGURATION to scsi-defs.h and scsi_command_name().

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
hw/scsi-bus.c
hw/scsi-defs.h
hw/scsi-disk.c

index e362671d877a5ba64de3c891aa5a12e9778e0199..09b6fa98dd2734b44c7d2525dc54c5112ed87c24 100644 (file)
@@ -440,6 +440,7 @@ static const char *scsi_command_name(uint8_t cmd)
 
         [ REWIND                   ] = "REWIND",
         [ REPORT_DENSITY_SUPPORT   ] = "REPORT_DENSITY_SUPPORT",
+        [ GET_CONFIGURATION        ] = "GET_CONFIGURATION",
         [ LOAD_UNLOAD              ] = "LOAD_UNLOAD",
         [ SET_CD_SPEED             ] = "SET_CD_SPEED",
         [ BLANK                    ] = "BLANK",
index 1701521ad7487e8e2744ebfb127b596699603304..fbcfaa6771820656aa2d800617a3fe7142887caa 100644 (file)
@@ -99,6 +99,7 @@
 /* from hw/scsi-generic.c */
 #define REWIND 0x01
 #define REPORT_DENSITY_SUPPORT 0x44
+#define GET_CONFIGURATION 0x46
 #define LOAD_UNLOAD 0xa6
 #define SET_CD_SPEED 0xbb
 #define BLANK 0xa1
index 6ba8f85cde94c4bd506f9faa154bebf553fd73d1..4a3e6fe1058f9d2e0d4318cdf878e5fcc9394456 100644 (file)
@@ -749,6 +749,13 @@ static int scsi_disk_emulate_command(SCSIRequest *req, uint8_t *outbuf)
     case SYNCHRONIZE_CACHE:
         bdrv_flush(bdrv);
         break;
+    case GET_CONFIGURATION:
+        memset(outbuf, 0, 8);
+        /* ??? This should probably return much more information.  For now
+           just return the basic header indicating the CD-ROM profile.  */
+        outbuf[7] = 8; // CD-ROM
+        buflen = 8;
+        break;
     default:
         goto illegal_request;
     }
@@ -865,6 +872,7 @@ static int32_t scsi_send_command(SCSIDevice *d, uint32_t tag,
     case READ_CAPACITY:
     case SYNCHRONIZE_CACHE:
     case READ_TOC:
+    case GET_CONFIGURATION:
         rc = scsi_disk_emulate_command(&r->req, outbuf);
         if (rc > 0) {
             r->iov.iov_len = rc;
@@ -893,14 +901,6 @@ static int32_t scsi_send_command(SCSIDevice *d, uint32_t tag,
         r->sector_count = len * s->cluster_size;
         is_write = 1;
         break;
-    case 0x46:
-        DPRINTF("Get Configuration (rt %d, maxlen %d)\n", buf[1] & 3, len);
-        memset(outbuf, 0, 8);
-        /* ??? This should probably return much more information.  For now
-           just return the basic header indicating the CD-ROM profile.  */
-        outbuf[7] = 8; // CD-ROM
-        r->iov.iov_len = 8;
-        break;
     case 0x9e:
         /* Service Action In subcommands. */
         if ((buf[1] & 31) == 0x10) {