[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-block] [Qemu-devel] [PATCH 4/5] atapi: call ide_set_irq before
From: |
John Snow |
Subject: |
Re: [Qemu-block] [Qemu-devel] [PATCH 4/5] atapi: call ide_set_irq before ide_transfer_start |
Date: |
Tue, 20 Mar 2018 20:35:19 -0400 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 |
On 02/23/2018 10:26 AM, Paolo Bonzini wrote:
> The ATAPI_INT_REASON_IO interrupt is raised when I/O starts, but in the
> AHCI case ide_set_irq was actually called at the end of a mutual recursion.
> Move it early, with the side effect that ide_transfer_start becomes a tail
> call in ide_atapi_cmd_reply_end.
>
Do you know in which spec it specifies that we should interrupt?
Seems okay, but I wanted to double check the wording in the spec (was
looking in scsi MMC and ATA8) and couldn't find it quickly.
> Signed-off-by: Paolo Bonzini <address@hidden>
> ---
> hw/ide/atapi.c | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/hw/ide/atapi.c b/hw/ide/atapi.c
> index c0509c8bf5..be99a929cf 100644
> --- a/hw/ide/atapi.c
> +++ b/hw/ide/atapi.c
> @@ -287,6 +287,7 @@ void ide_atapi_cmd_reply_end(IDEState *s)
> } else {
> /* a new transfer is needed */
> s->nsector = (s->nsector & ~7) | ATAPI_INT_REASON_IO;
> + ide_set_irq(s->bus);
> byte_count_limit = atapi_byte_count_limit(s);
> trace_ide_atapi_cmd_reply_end_bcl(s, byte_count_limit);
> size = s->packet_transfer_size;
> @@ -307,10 +308,9 @@ void ide_atapi_cmd_reply_end(IDEState *s)
> s->packet_transfer_size -= size;
> s->elementary_transfer_size -= size;
> s->io_buffer_index += size;
> + trace_ide_atapi_cmd_reply_end_new(s, s->status);
> ide_transfer_start(s, s->io_buffer + s->io_buffer_index - size,
> size, ide_atapi_cmd_reply_end);
> - ide_set_irq(s->bus);
> - trace_ide_atapi_cmd_reply_end_new(s, s->status);
> }
> }
> }
>
- Re: [Qemu-block] [Qemu-devel] [PATCH 4/5] atapi: call ide_set_irq before ide_transfer_start,
John Snow <=