mirror of
https://git.proxmox.com/git/qemu
synced 2025-07-19 19:36:16 +00:00
scsi: fix sign extension problems
When assigning a 32-bit value to cmd->xfer (which is 64-bits) it can be erroneously sign extended because the intermediate 32-bit computation is signed. Fix this by standardizing on the ld*_be_p functions. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
7a3f5fe9af
commit
bd5da23265
@ -542,15 +542,15 @@ static int scsi_req_length(SCSICommand *cmd, SCSIDevice *dev, uint8_t *buf)
|
|||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
case 2:
|
case 2:
|
||||||
cmd->xfer = buf[8] | (buf[7] << 8);
|
cmd->xfer = lduw_be_p(&buf[7]);
|
||||||
cmd->len = 10;
|
cmd->len = 10;
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
cmd->xfer = buf[13] | (buf[12] << 8) | (buf[11] << 16) | (buf[10] << 24);
|
cmd->xfer = ldl_be_p(&buf[10]);
|
||||||
cmd->len = 16;
|
cmd->len = 16;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
cmd->xfer = buf[9] | (buf[8] << 8) | (buf[7] << 16) | (buf[6] << 24);
|
cmd->xfer = ldl_be_p(&buf[6]);
|
||||||
cmd->len = 12;
|
cmd->len = 12;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -710,23 +710,15 @@ static uint64_t scsi_cmd_lba(SCSICommand *cmd)
|
|||||||
|
|
||||||
switch (buf[0] >> 5) {
|
switch (buf[0] >> 5) {
|
||||||
case 0:
|
case 0:
|
||||||
lba = (uint64_t) buf[3] | ((uint64_t) buf[2] << 8) |
|
lba = ldl_be_p(&buf[0]) & 0x1fffff;
|
||||||
(((uint64_t) buf[1] & 0x1f) << 16);
|
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
case 2:
|
case 2:
|
||||||
lba = (uint64_t) buf[5] | ((uint64_t) buf[4] << 8) |
|
case 5:
|
||||||
((uint64_t) buf[3] << 16) | ((uint64_t) buf[2] << 24);
|
lba = ldl_be_p(&buf[2]);
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
lba = (uint64_t) buf[9] | ((uint64_t) buf[8] << 8) |
|
lba = ldq_be_p(&buf[2]);
|
||||||
((uint64_t) buf[7] << 16) | ((uint64_t) buf[6] << 24) |
|
|
||||||
((uint64_t) buf[5] << 32) | ((uint64_t) buf[4] << 40) |
|
|
||||||
((uint64_t) buf[3] << 48) | ((uint64_t) buf[2] << 56);
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
lba = (uint64_t) buf[5] | ((uint64_t) buf[4] << 8) |
|
|
||||||
((uint64_t) buf[3] << 16) | ((uint64_t) buf[2] << 24);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
lba = -1;
|
lba = -1;
|
||||||
|
Loading…
Reference in New Issue
Block a user