aboutsummaryrefslogtreecommitdiff
path: root/qemu-tech.texi
diff options
context:
space:
mode:
authorAndrea Arcangeli <aarcange@redhat.com>2010-07-27 21:04:36 +0200
committerKevin Wolf <kwolf@redhat.com>2010-08-03 15:57:22 +0200
commit953844d102f5b682f0835f021f2ed2ad9fb7734c (patch)
treeb2f013c6ebe0d9ff182747871af16ee5286ab3f5 /qemu-tech.texi
parent4be9762adb0947a353e6efef2fed354f69218bfb (diff)
downloadqemu-953844d102f5b682f0835f021f2ed2ad9fb7734c.zip
qemu-953844d102f5b682f0835f021f2ed2ad9fb7734c.tar.gz
qemu-953844d102f5b682f0835f021f2ed2ad9fb7734c.tar.bz2
ide: Avoid canceling IDE DMA
The reason for not actually canceling the I/O is because with virtualization and lots of VM running, a guest fs may mistake a overload of the host, as an IDE timeout. So rather than canceling the I/O, it's safer to wait I/O completion and simulate that the I/O has completed just before the io cancellation was requested by the guest. This way if ntfs or an app writes data without checking for -EIO retval, and it thinks the write has succeeded, it's less likely to run into troubles. Similar issues for reads. Furthermore because the DMA operation is splitted into many synchronous aio_read/write if there's more than one entry in the SG table, without this patch the DMA would be cancelled in the middle, something we've no idea if it happens on real hardware too or not. Overall this seems a great risk for zero gain. This approach is sure safer than previous code given we can't pretend all guest fs code out there to check for errors and reply the DMA if it was completed partially, given a timeout would never materialize on a real harddisk unless there are defective blocks (and defective blocks are practically only an issue for reads never for writes in any recent hardware as writing to blocks is the way to fix them) or the harddisk breaks as a whole. Signed-off-by: Izik Eidus <ieidus@redhat.com> Signed-off-by: Andrea Arcangeli <aarcange@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Diffstat (limited to 'qemu-tech.texi')
0 files changed, 0 insertions, 0 deletions