From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:51437) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1UG4xl-0001Ek-Fz for qemu-devel@nongnu.org; Thu, 14 Mar 2013 06:00:46 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1UG4xd-0005g8-Lo for qemu-devel@nongnu.org; Thu, 14 Mar 2013 06:00:41 -0400 Received: from mx1.redhat.com ([209.132.183.28]:32789) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1UG4xd-0005g2-Dg for qemu-devel@nongnu.org; Thu, 14 Mar 2013 06:00:33 -0400 Message-ID: <51419FB8.6010805@redhat.com> Date: Thu, 14 Mar 2013 11:00:24 +0100 From: Paolo Bonzini MIME-Version: 1.0 References: <1363069782-10735-1-git-send-email-asias@redhat.com> <20130314042514.GA28504@hj.localdomain> <20130314092542.GB7892@hj.localdomain> <20130314094643.GD14977@redhat.com> In-Reply-To: <20130314094643.GD14977@redhat.com> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH V2 WIP 0/2] vhost-scsi: new device supporting the tcm_vhost Linux kernel module List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: "Michael S. Tsirkin" Cc: kvm@vger.kernel.org, Rusty Russell , qemu-devel@nongnu.org, Nicholas Bellinger , virtualization@lists.linux-foundation.org, target-devel@vger.kernel.org, Stefan Hajnoczi , Asias He >> --------------- 8 ---------------> seabios patch: >> diff --git a/src/virtio-scsi.c b/src/virtio-scsi.c >> index 879ddfb..4de1255 100644 >> --- a/src/virtio-scsi.c >> +++ b/src/virtio-scsi.c >> @@ -147,6 +147,9 @@ init_virtio_scsi(struct pci_device *pci) >> goto fail; >> } >> >> + vp_set_status(ioaddr, VIRTIO_CONFIG_S_ACKNOWLEDGE | >> + VIRTIO_CONFIG_S_DRIVER | VIRTIO_CONFIG_S_DRIVER_OK); >> + >> int i, tot; >> for (tot = 0, i = 0; i < 256; i++) >> tot += virtio_scsi_scan_target(pci, ioaddr, vq, i); >> @@ -154,8 +157,6 @@ init_virtio_scsi(struct pci_device *pci) >> if (!tot) >> goto fail; >> >> - vp_set_status(ioaddr, VIRTIO_CONFIG_S_ACKNOWLEDGE | >> - VIRTIO_CONFIG_S_DRIVER | VIRTIO_CONFIG_S_DRIVER_OK); >> return; >> >> fail: ACK. >> diff --git a/src/virtio-scsi.h b/src/virtio-scsi.h >> index bbfbf30..96c3701 100644 >> --- a/src/virtio-scsi.h >> +++ b/src/virtio-scsi.h >> @@ -26,7 +26,7 @@ struct virtio_scsi_req_cmd { >> u8 prio; >> u8 crn; >> char cdb[VIRTIO_SCSI_CDB_SIZE]; >> -}; >> +} __attribute__((packed)); >> >> /* This is the first element of the "in" scatter-gather list. */ >> struct virtio_scsi_resp_cmd { >> @@ -36,7 +36,7 @@ struct virtio_scsi_resp_cmd { >> u8 status; >> u8 response; >> u8 sense[VIRTIO_SCSI_SENSE_SIZE]; >> -}; >> +} __attribute__((packed)); >> >> #define VIRTIO_SCSI_S_OK 0 > > I see, the padding creates the problem? Looks like it does for req_cmd (which has length 51 and is padded to 56). QEMU incorrectly relies on the framing. Both of these are SeaBIOS bugs, please do submit the patch. Paolo