mirror of
https://github.com/qemu/qemu.git
synced 2024-11-26 12:23:36 +08:00
ide: Generate BLOCK_IO_ERROR QMP event
Just call bdrv_mon_event() in the right place. Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
2582bfedd2
commit
7ad7e3c3bf
@ -480,14 +480,17 @@ static int ide_handle_rw_error(IDEState *s, int error, int op)
|
||||
int is_read = (op & BM_STATUS_RETRY_READ);
|
||||
BlockInterfaceErrorAction action = drive_get_on_error(s->bs, is_read);
|
||||
|
||||
if (action == BLOCK_ERR_IGNORE)
|
||||
if (action == BLOCK_ERR_IGNORE) {
|
||||
bdrv_mon_event(s->bs, BDRV_ACTION_IGNORE, is_read);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if ((error == ENOSPC && action == BLOCK_ERR_STOP_ENOSPC)
|
||||
|| action == BLOCK_ERR_STOP_ANY) {
|
||||
s->bus->bmdma->unit = s->unit;
|
||||
s->bus->bmdma->status |= op;
|
||||
vm_stop(0);
|
||||
bdrv_mon_event(s->bs, BDRV_ACTION_STOP, is_read);
|
||||
} else {
|
||||
if (op & BM_STATUS_DMA_RETRY) {
|
||||
dma_buf_commit(s, 0);
|
||||
@ -495,6 +498,7 @@ static int ide_handle_rw_error(IDEState *s, int error, int op)
|
||||
} else {
|
||||
ide_rw_error(s);
|
||||
}
|
||||
bdrv_mon_event(s->bs, BDRV_ACTION_REPORT, is_read);
|
||||
}
|
||||
|
||||
return 1;
|
||||
|
Loading…
Reference in New Issue
Block a user