scsi-generic: avoid out-of-bounds access to VPD page list
A device can report an excessive number of VPD pages when asked for a list; this can cause an out-of-bounds access to buf in scsi_generic_set_vpd_bl_emulation. It should not happen, but it is technically not incorrect so handle it: do not check any byte past the allocation length that was sent to the INQUIRY command. Reported-by: Max Reitz <mreitz@redhat.com> Reviewed-by: Max Reitz <mreitz@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
6c219fc8a1
commit
57dbb58d80
@ -538,7 +538,7 @@ static void scsi_generic_set_vpd_bl_emulation(SCSIDevice *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
page_len = buf[3];
|
page_len = buf[3];
|
||||||
for (i = 4; i < page_len + 4; i++) {
|
for (i = 4; i < MIN(sizeof(buf), page_len + 4); i++) {
|
||||||
if (buf[i] == 0xb0) {
|
if (buf[i] == 0xb0) {
|
||||||
s->needs_vpd_bl_emulation = false;
|
s->needs_vpd_bl_emulation = false;
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user