summaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorCornelia Huck <cornelia.huck@de.ibm.com>2015-06-29 16:44:01 +0200
committerPaolo Bonzini <pbonzini@redhat.com>2015-07-03 18:55:18 +0200
commit431dae778aea4eed31bd12e5ee82edc571cd4d70 (patch)
treead254fb0e1540501d690508b2ddf0eaea38815b8 /arch
parentKVM: x86: keep track of LVT0 changes under APICv (diff)
downloadlinux-431dae778aea4eed31bd12e5ee82edc571cd4d70.tar.xz
linux-431dae778aea4eed31bd12e5ee82edc571cd4d70.zip
KVM: s390: virtio-ccw: don't overwrite config space values
Eric noticed problems with vhost-scsi and virtio-ccw: vhost-scsi complained about overwriting values in the config space, which was triggered by a broken implementation of virtio-ccw's config get/set routines. It was probably sheer luck that we did not hit this before. When writing a value to the config space, the WRITE_CONF ccw will always write from the beginning of the config space up to and including the value to be set. If the config space up to the value has not yet been retrieved from the device, however, we'll end up overwriting values. Keep track of the known config space and update if needed to avoid this. Moreover, READ_CONF will only read the number of bytes it has been instructed to retrieve, so we must not copy more than that to the buffer, or we might overwrite trailing values. Reported-by: Eric Farman <farman@linux.vnet.ibm.com> Signed-off-by: Cornelia Huck <cornelia.huck@de.ibm.com> Reviewed-by: Eric Farman <farman@linux.vnet.ibm.com> Tested-by: Eric Farman <farman@linux.vnet.ibm.com> Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com> Cc: stable@vger.kernel.org Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'arch')
0 files changed, 0 insertions, 0 deletions