From 72bcca73c7a67c8506fa737618861ad413dabf38 Mon Sep 17 00:00:00 2001 From: Kevin Wolf Date: Tue, 20 Nov 2012 17:27:44 +0100 Subject: ide: Fix status register after short PRDs When failing a request because the length of the regions described by the PRDT was too short for the requested number of sectors, the IDE emulation forgot to update the status register, so that the device would keep the BSY flag set indefinitely. Signed-off-by: Kevin Wolf Signed-off-by: Stefan Hajnoczi --- hw/ide/core.c | 1 + 1 file changed, 1 insertion(+) (limited to 'hw/ide') diff --git a/hw/ide/core.c b/hw/ide/core.c index c2ab78753a..8da894f240 100644 --- a/hw/ide/core.c +++ b/hw/ide/core.c @@ -625,6 +625,7 @@ void ide_dma_cb(void *opaque, int ret) if (s->bus->dma->ops->prepare_buf(s->bus->dma, ide_cmd_is_read(s)) == 0) { /* The PRDs were too short. Reset the Active bit, but don't raise an * interrupt. */ + s->status = READY_STAT | SEEK_STAT; goto eot; } -- cgit v1.2.1