WIN_WRITE_MULTIPLE now correctly fails with command aborted if ide->blocksize = 0, instead of a fatal().

This commit is contained in:
OBattler 2022-07-26 00:18:28 +02:00
parent 42cb69fd66
commit a064918133

View file

@ -1682,8 +1682,7 @@ ide_writeb(uint16_t addr, uint8_t val, void *priv)
return; return;
case WIN_WRITE_MULTIPLE: case WIN_WRITE_MULTIPLE:
if (!ide->blocksize && (ide->type != IDE_ATAPI)) /* Fatal removed for the same reason as for WIN_READ_MULTIPLE. */
fatal("Write_MULTIPLE - blocksize = 0\n");
ide->blockcount = 0; ide->blockcount = 0;
/* Turn on the activity indicator *here* so that it gets turned on /* Turn on the activity indicator *here* so that it gets turned on
less times. */ less times. */
@ -2410,7 +2409,13 @@ ide_callback(void *priv)
return; return;
case WIN_WRITE_MULTIPLE: case WIN_WRITE_MULTIPLE:
if (ide->type == IDE_ATAPI) /* According to the official ATA reference:
If the Read Multiple command is attempted before the Set Multiple Mode
command has been executed or when Read Multiple commands are
disabled, the Read Multiple operation is rejected with an Aborted Com-
mand error. */
if ((ide->type == IDE_ATAPI) || !ide->blocksize)
goto abort_cmd; goto abort_cmd;
if (!ide->lba && (ide->cfg_spt == 0)) if (!ide->lba && (ide->cfg_spt == 0))
goto id_not_found; goto id_not_found;