[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-stable] [PATCH 2/7] scsi-generic: fix sign extension of READ CAPAC
From: |
Paolo Bonzini |
Subject: |
[Qemu-stable] [PATCH 2/7] scsi-generic: fix sign extension of READ CAPACITY(10) data |
Date: |
Tue, 18 Jun 2013 16:16:51 +0200 |
Issuing the READ CAPACITY(10) command in the guest will cause QEMU
to update its knowledge of the maximum accessible LBA in the disk.
The recorded maximum LBA will be wrong if the disk is bigger than
1TB, because ldl_be_p returns a signed int.
When this is fixed, a latent bug will be unmasked. If the READ
CAPACITY(10) command reported an overflow (0xFFFFFFFF), we must
not overwrite the previously-known maximum accessible LBA, or the guest
will fail to access the disk above the first 2TB.
Cc: address@hidden
Signed-off-by: Paolo Bonzini <address@hidden>
---
hw/scsi/scsi-generic.c | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/hw/scsi/scsi-generic.c b/hw/scsi/scsi-generic.c
index 2a9a561..19bd36c 100644
--- a/hw/scsi/scsi-generic.c
+++ b/hw/scsi/scsi-generic.c
@@ -198,9 +198,10 @@ static void scsi_read_complete(void * opaque, int ret)
scsi_command_complete(r, 0);
} else {
/* Snoop READ CAPACITY output to set the blocksize. */
- if (r->req.cmd.buf[0] == READ_CAPACITY_10) {
+ if (r->req.cmd.buf[0] == READ_CAPACITY_10 &&
+ (ldl_be_p(&r->buf[0]) != 0xffffffffU || s->max_lba == 0)) {
s->blocksize = ldl_be_p(&r->buf[4]);
- s->max_lba = ldl_be_p(&r->buf[0]);
+ s->max_lba = ldl_be_p(&r->buf[0]) & 0xffffffffULL;
} else if (r->req.cmd.buf[0] == SERVICE_ACTION_IN_16 &&
(r->req.cmd.buf[1] & 31) == SAI_READ_CAPACITY_16) {
s->blocksize = ldl_be_p(&r->buf[8]);
--
1.8.1.4
- [Qemu-stable] [PULL 0/7] SCSI patches for 2013-06-18 (including 1.5.1 patches), Paolo Bonzini, 2013/06/18
- [Qemu-stable] [PATCH 1/7] scsi: reset cdrom tray statuses on scsi_disk_reset, Paolo Bonzini, 2013/06/18
- [Qemu-stable] [PATCH 2/7] scsi-generic: fix sign extension of READ CAPACITY(10) data,
Paolo Bonzini <=
- [Qemu-stable] [PATCH 3/7] scsi-generic: check the return value of bdrv_aio_ioctl in execute_command, Paolo Bonzini, 2013/06/18
- [Qemu-stable] [PATCH 7/7] iscsi: reorganize iscsi_readcapacity_sync, Paolo Bonzini, 2013/06/18
- [Qemu-stable] [PATCH 6/7] iscsi: simplify freeing of tasks, Paolo Bonzini, 2013/06/18
- [Qemu-stable] [PATCH 5/7] vhost-scsi: fix k->set_guest_notifiers() NULL dereference, Paolo Bonzini, 2013/06/18
- [Qemu-stable] [PATCH 4/7] scsi-disk: scsi-block device for scsi pass-through should not be removable, Paolo Bonzini, 2013/06/18