summaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorJohn Snow2014-09-13 05:51:12 +0200
committerStefan Hajnoczi2014-09-22 12:38:44 +0200
commitd735b620b58f2fdfddc8e641e9feac3c9671a49d (patch)
treea101a2c0bf72f2b3d6e14630ffcb61cb8d05518d /include
parentblock/vhdx.c: Mark parent_vhdx_guid variable as unused (diff)
downloadqemu-d735b620b58f2fdfddc8e641e9feac3c9671a49d.tar.gz
qemu-d735b620b58f2fdfddc8e641e9feac3c9671a49d.tar.xz
qemu-d735b620b58f2fdfddc8e641e9feac3c9671a49d.zip
ide/atapi: Mark non-data commands as complete
When the command completion code in IDE and AHCI was unified to put all command completion inside of a callback, "cmd_done," we neglected to ensure that all AHCI/ATAPI command paths would eventually register as finished. for the PCI interface to IDE this is not a problem because cmd_done is a nop, but the AHCI implementation needs to send a D2H_REG_FIS and interrupt back to the guest to inform of completion. This patch adds calls to ide_stop_transfer, which calls ide_cmd_done, inside of ide_atapi_cmd_ok and ide_atapi_cmd_error. This fixes regressions observed by trying to boot QEMU with a Fedora 20 live CD under Q35/AHCI, which uses ATAPI command 0x00, which is a status check that may cause a hang because we never complete, and ATAPI command 0x56, which is unsupported by our current implementation and results in an error that we never report back to the guest. Signed-off-by: John Snow <jsnow@redhat.com> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Diffstat (limited to 'include')
0 files changed, 0 insertions, 0 deletions