qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v2 32/42] esp: latch individual bits in ESP_RINTR register


From: Laurent Vivier
Subject: Re: [PATCH v2 32/42] esp: latch individual bits in ESP_RINTR register
Date: Wed, 3 Mar 2021 20:48:34 +0100
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.7.0

Le 09/02/2021 à 20:30, Mark Cave-Ayland a écrit :
> Currently the ESP_RINTR register is set to a specific value as required within
> the ESP state machine. In order to implement the upcoming deferred interrupt
> functionality it is necessary to set individual bits within ESP_RINTR so that
> a deferred interrupt will not overwrite the value of any other interrupt bits.
> 
> This also requires fixing up a few locations where the ESP_RINTR and ESP_RSEQ
> registers are set/reset unexpectedly.
> 
> Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
> ---
>  hw/scsi/esp.c | 29 +++++++++++++----------------
>  1 file changed, 13 insertions(+), 16 deletions(-)
> 
> diff --git a/hw/scsi/esp.c b/hw/scsi/esp.c
> index 0994673ff8..728d4ddf99 100644
> --- a/hw/scsi/esp.c
> +++ b/hw/scsi/esp.c
> @@ -178,7 +178,7 @@ static int esp_select(ESPState *s)
>      if (!s->current_dev) {
>          /* No such drive */
>          s->rregs[ESP_RSTAT] = 0;
> -        s->rregs[ESP_RINTR] = INTR_DC;
> +        s->rregs[ESP_RINTR] |= INTR_DC;
>          s->rregs[ESP_RSEQ] = SEQ_0;
>          esp_raise_irq(s);
>          return -1;
> @@ -245,7 +245,7 @@ static void do_busid_cmd(ESPState *s, uint8_t *buf, 
> uint8_t busid)
>          }
>          scsi_req_continue(s->current_req);
>      }
> -    s->rregs[ESP_RINTR] = INTR_BS | INTR_FC;
> +    s->rregs[ESP_RINTR] |= INTR_BS | INTR_FC;
>      s->rregs[ESP_RSEQ] = SEQ_CD;
>      esp_raise_irq(s);
>      esp_lower_drq(s);
> @@ -326,7 +326,7 @@ static void satn_stop_pdma_cb(ESPState *s)
>          trace_esp_handle_satn_stop(s->cmdlen);
>          s->do_cmd = 1;
>          s->rregs[ESP_RSTAT] = STAT_TC | STAT_CD;
> -        s->rregs[ESP_RINTR] = INTR_BS | INTR_FC;
> +        s->rregs[ESP_RINTR] |= INTR_BS | INTR_FC;
>          s->rregs[ESP_RSEQ] = SEQ_CD;
>          esp_raise_irq(s);
>      }
> @@ -346,8 +346,8 @@ static void handle_satn_stop(ESPState *s)
>          trace_esp_handle_satn_stop(s->cmdlen);
>          s->cmdlen = cmdlen;
>          s->do_cmd = 1;
> -        s->rregs[ESP_RSTAT] = STAT_TC | STAT_CD;
> -        s->rregs[ESP_RINTR] = INTR_BS | INTR_FC;
> +        s->rregs[ESP_RSTAT] = STAT_CD;
> +        s->rregs[ESP_RINTR] |= INTR_BS | INTR_FC;
>          s->rregs[ESP_RSEQ] = SEQ_CD;
>          esp_raise_irq(s);
>      } else if (cmdlen == 0) {
> @@ -362,7 +362,7 @@ static void handle_satn_stop(ESPState *s)
>  static void write_response_pdma_cb(ESPState *s)
>  {
>      s->rregs[ESP_RSTAT] = STAT_TC | STAT_ST;
> -    s->rregs[ESP_RINTR] = INTR_BS | INTR_FC;
> +    s->rregs[ESP_RINTR] |= INTR_BS | INTR_FC;
>      s->rregs[ESP_RSEQ] = SEQ_CD;
>      esp_raise_irq(s);
>  }
> @@ -376,7 +376,7 @@ static void write_response(ESPState *s)
>          if (s->dma_memory_write) {
>              s->dma_memory_write(s->dma_opaque, s->ti_buf, 2);
>              s->rregs[ESP_RSTAT] = STAT_TC | STAT_ST;
> -            s->rregs[ESP_RINTR] = INTR_BS | INTR_FC;
> +            s->rregs[ESP_RINTR] |= INTR_BS | INTR_FC;
>              s->rregs[ESP_RSEQ] = SEQ_CD;
>          } else {
>              s->pdma_cb = write_response_pdma_cb;
> @@ -395,7 +395,7 @@ static void write_response(ESPState *s)
>  static void esp_dma_done(ESPState *s)
>  {
>      s->rregs[ESP_RSTAT] |= STAT_TC;
> -    s->rregs[ESP_RINTR] = INTR_BS;
> +    s->rregs[ESP_RINTR] |= INTR_BS;
>      s->rregs[ESP_RSEQ] = 0;
>      s->rregs[ESP_RFLAGS] = 0;
>      esp_set_tc(s, 0);
> @@ -701,7 +701,7 @@ uint64_t esp_reg_read(ESPState *s, uint32_t saddr)
>          val = s->rregs[ESP_RINTR];
>          s->rregs[ESP_RINTR] = 0;
>          s->rregs[ESP_RSTAT] &= ~STAT_TC;
> -        s->rregs[ESP_RSEQ] = SEQ_CD;
> +        s->rregs[ESP_RSEQ] = SEQ_0;
>          esp_lower_irq(s);
>          if (s->deferred_complete) {
>              esp_report_command_complete(s, s->deferred_status);
> @@ -772,9 +772,6 @@ void esp_reg_write(ESPState *s, uint32_t saddr, uint64_t 
> val)
>              /*s->ti_size = 0;*/
>              s->ti_wptr = 0;
>              s->ti_rptr = 0;
> -            s->rregs[ESP_RINTR] = INTR_FC;
> -            s->rregs[ESP_RSEQ] = 0;
> -            s->rregs[ESP_RFLAGS] = 0;
>              break;
>          case CMD_RESET:
>              trace_esp_mem_writeb_cmd_reset(val);
> @@ -782,8 +779,8 @@ void esp_reg_write(ESPState *s, uint32_t saddr, uint64_t 
> val)
>              break;
>          case CMD_BUSRESET:
>              trace_esp_mem_writeb_cmd_bus_reset(val);
> -            s->rregs[ESP_RINTR] = INTR_RST;
>              if (!(s->wregs[ESP_CFG1] & CFG1_RESREPT)) {
> +                s->rregs[ESP_RINTR] |= INTR_RST;
>                  esp_raise_irq(s);
>              }
>              break;
> @@ -794,12 +791,12 @@ void esp_reg_write(ESPState *s, uint32_t saddr, 
> uint64_t val)
>          case CMD_ICCS:
>              trace_esp_mem_writeb_cmd_iccs(val);
>              write_response(s);
> -            s->rregs[ESP_RINTR] = INTR_FC;
> +            s->rregs[ESP_RINTR] |= INTR_FC;
>              s->rregs[ESP_RSTAT] |= STAT_MI;
>              break;
>          case CMD_MSGACC:
>              trace_esp_mem_writeb_cmd_msgacc(val);
> -            s->rregs[ESP_RINTR] = INTR_DC;
> +            s->rregs[ESP_RINTR] |= INTR_DC;
>              s->rregs[ESP_RSEQ] = 0;
>              s->rregs[ESP_RFLAGS] = 0;
>              esp_raise_irq(s);
> @@ -807,7 +804,7 @@ void esp_reg_write(ESPState *s, uint32_t saddr, uint64_t 
> val)
>          case CMD_PAD:
>              trace_esp_mem_writeb_cmd_pad(val);
>              s->rregs[ESP_RSTAT] = STAT_TC;
> -            s->rregs[ESP_RINTR] = INTR_FC;
> +            s->rregs[ESP_RINTR] |= INTR_FC;
>              s->rregs[ESP_RSEQ] = 0;
>              break;
>          case CMD_SATN:
> 

Reviewed-by: Laurent Vivier <laurent@vivier.eu>



reply via email to

[Prev in Thread] Current Thread [Next in Thread]