mirror of
https://git.proxmox.com/git/qemu
synced 2025-06-15 12:44:04 +00:00
fdc: fix FD_SR0_SEEK for initial seek on DMA transfers
fdctrl_start_transfer() used to set FD_SR0_SEEK no matter if there actually was a seek or not. This is obviously wrong. fdctrl_start_transfer() has this information because it performs the initial seek itself. Signed-off-by: Hervé Poussineau <hpoussin@reactos.org> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
c5139bd9a9
commit
d6ed4e2106
8
hw/fdc.c
8
hw/fdc.c
@ -1179,7 +1179,6 @@ static void fdctrl_start_transfer(FDCtrl *fdctrl, int direction)
|
|||||||
{
|
{
|
||||||
FDrive *cur_drv;
|
FDrive *cur_drv;
|
||||||
uint8_t kh, kt, ks;
|
uint8_t kh, kt, ks;
|
||||||
int did_seek = 0;
|
|
||||||
|
|
||||||
SET_CUR_DRV(fdctrl, fdctrl->fifo[1] & FD_DOR_SELMASK);
|
SET_CUR_DRV(fdctrl, fdctrl->fifo[1] & FD_DOR_SELMASK);
|
||||||
cur_drv = get_cur_drv(fdctrl);
|
cur_drv = get_cur_drv(fdctrl);
|
||||||
@ -1213,7 +1212,7 @@ static void fdctrl_start_transfer(FDCtrl *fdctrl, int direction)
|
|||||||
fdctrl->fifo[5] = ks;
|
fdctrl->fifo[5] = ks;
|
||||||
return;
|
return;
|
||||||
case 1:
|
case 1:
|
||||||
did_seek = 1;
|
fdctrl->status0 |= FD_SR0_SEEK;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -1240,10 +1239,6 @@ static void fdctrl_start_transfer(FDCtrl *fdctrl, int direction)
|
|||||||
fdctrl->data_state |= FD_STATE_MULTI;
|
fdctrl->data_state |= FD_STATE_MULTI;
|
||||||
else
|
else
|
||||||
fdctrl->data_state &= ~FD_STATE_MULTI;
|
fdctrl->data_state &= ~FD_STATE_MULTI;
|
||||||
if (did_seek)
|
|
||||||
fdctrl->data_state |= FD_STATE_SEEK;
|
|
||||||
else
|
|
||||||
fdctrl->data_state &= ~FD_STATE_SEEK;
|
|
||||||
if (fdctrl->fifo[5] == 00) {
|
if (fdctrl->fifo[5] == 00) {
|
||||||
fdctrl->data_len = fdctrl->fifo[8];
|
fdctrl->data_len = fdctrl->fifo[8];
|
||||||
} else {
|
} else {
|
||||||
@ -1286,7 +1281,6 @@ static void fdctrl_start_transfer(FDCtrl *fdctrl, int direction)
|
|||||||
if (direction != FD_DIR_WRITE)
|
if (direction != FD_DIR_WRITE)
|
||||||
fdctrl->msr |= FD_MSR_DIO;
|
fdctrl->msr |= FD_MSR_DIO;
|
||||||
/* IO based transfer: calculate len */
|
/* IO based transfer: calculate len */
|
||||||
fdctrl->status0 |= FD_SR0_SEEK;
|
|
||||||
fdctrl_raise_irq(fdctrl);
|
fdctrl_raise_irq(fdctrl);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user