From: Hervé Poussineau Date: Mon, 6 Feb 2012 21:29:03 +0000 (+0100) Subject: fdc: set busy bit when starting a command X-Git-Tag: v1.1-rc0~290^2~25 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1457a75843740b0433edfc88666c793858f4423a;p=thirdparty%2Fqemu.git fdc: set busy bit when starting a command This bit must be active while a command is currently executed. Signed-off-by: Hervé Poussineau Signed-off-by: Kevin Wolf --- diff --git a/hw/fdc.c b/hw/fdc.c index 64e635a849a..05edc3aa3c6 100644 --- a/hw/fdc.c +++ b/hw/fdc.c @@ -1446,7 +1446,6 @@ static void fdctrl_handle_readid(FDCtrl *fdctrl, int direction) { FDrive *cur_drv = get_cur_drv(fdctrl); - /* XXX: should set main status register to busy */ cur_drv->head = (fdctrl->fifo[1] >> 2) & 1; qemu_mod_timer(fdctrl->result_timer, qemu_get_clock_ns(vm_clock) + (get_ticks_per_sec() / 50)); @@ -1734,6 +1733,7 @@ static void fdctrl_write_data(FDCtrl *fdctrl, uint32_t value) pos = command_to_handler[value & 0xff]; FLOPPY_DPRINTF("%s command\n", handlers[pos].name); fdctrl->data_len = handlers[pos].parameters + 1; + fdctrl->msr |= FD_MSR_CMDBUSY; } FLOPPY_DPRINTF("%s: %02x\n", __func__, value);