Message ID | 9752d94b9333062d8e3b74dffafc20f348167d95.1333467746.git.atar4qemu@gmail.com |
---|---|
State | New |
Headers | show |
Thanks, applied both. On Tue, Apr 3, 2012 at 15:49, Artyom Tarasenko <atar4qemu@gmail.com> wrote: > Don't produce stray irq 5, don't overwrite ivec_data if still busy with > processing of the previous interrupt. > > Signed-off-by: Artyom Tarasenko <atar4qemu@gmail.com> > --- > hw/sun4u.c | 29 ++++++++++++++++------------- > 1 files changed, 16 insertions(+), 13 deletions(-) > > diff --git a/hw/sun4u.c b/hw/sun4u.c > index 1d67691..9d28194 100644 > --- a/hw/sun4u.c > +++ b/hw/sun4u.c > @@ -315,19 +315,22 @@ static void cpu_set_ivec_irq(void *opaque, int irq, int level) > CPUSPARCState *env = opaque; > > if (level) { > - CPUIRQ_DPRINTF("Raise IVEC IRQ %d\n", irq); > - env->interrupt_index = TT_IVEC; > - env->pil_in |= 1 << 5; > - env->ivec_status |= 0x20; > - env->ivec_data[0] = (0x1f << 6) | irq; > - env->ivec_data[1] = 0; > - env->ivec_data[2] = 0; > - cpu_interrupt(env, CPU_INTERRUPT_HARD); > - } else { > - CPUIRQ_DPRINTF("Lower IVEC IRQ %d\n", irq); > - env->pil_in &= ~(1 << 5); > - env->ivec_status &= ~0x20; > - cpu_reset_interrupt(env, CPU_INTERRUPT_HARD); > + if (!(env->ivec_status & 0x20)) { > + CPUIRQ_DPRINTF("Raise IVEC IRQ %d\n", irq); > + env->halted = 0; > + env->interrupt_index = TT_IVEC; > + env->ivec_status |= 0x20; > + env->ivec_data[0] = (0x1f << 6) | irq; > + env->ivec_data[1] = 0; > + env->ivec_data[2] = 0; > + cpu_interrupt(env, CPU_INTERRUPT_HARD); > + } > + } else { > + if (env->ivec_status & 0x20) { > + CPUIRQ_DPRINTF("Lower IVEC IRQ %d\n", irq); > + env->ivec_status &= ~0x20; > + cpu_reset_interrupt(env, CPU_INTERRUPT_HARD); > + } > } > } > > -- > 1.7.3.4 >
diff --git a/hw/sun4u.c b/hw/sun4u.c index 1d67691..9d28194 100644 --- a/hw/sun4u.c +++ b/hw/sun4u.c @@ -315,19 +315,22 @@ static void cpu_set_ivec_irq(void *opaque, int irq, int level) CPUSPARCState *env = opaque; if (level) { - CPUIRQ_DPRINTF("Raise IVEC IRQ %d\n", irq); - env->interrupt_index = TT_IVEC; - env->pil_in |= 1 << 5; - env->ivec_status |= 0x20; - env->ivec_data[0] = (0x1f << 6) | irq; - env->ivec_data[1] = 0; - env->ivec_data[2] = 0; - cpu_interrupt(env, CPU_INTERRUPT_HARD); - } else { - CPUIRQ_DPRINTF("Lower IVEC IRQ %d\n", irq); - env->pil_in &= ~(1 << 5); - env->ivec_status &= ~0x20; - cpu_reset_interrupt(env, CPU_INTERRUPT_HARD); + if (!(env->ivec_status & 0x20)) { + CPUIRQ_DPRINTF("Raise IVEC IRQ %d\n", irq); + env->halted = 0; + env->interrupt_index = TT_IVEC; + env->ivec_status |= 0x20; + env->ivec_data[0] = (0x1f << 6) | irq; + env->ivec_data[1] = 0; + env->ivec_data[2] = 0; + cpu_interrupt(env, CPU_INTERRUPT_HARD); + } + } else { + if (env->ivec_status & 0x20) { + CPUIRQ_DPRINTF("Lower IVEC IRQ %d\n", irq); + env->ivec_status &= ~0x20; + cpu_reset_interrupt(env, CPU_INTERRUPT_HARD); + } } }
Don't produce stray irq 5, don't overwrite ivec_data if still busy with processing of the previous interrupt. Signed-off-by: Artyom Tarasenko <atar4qemu@gmail.com> --- hw/sun4u.c | 29 ++++++++++++++++------------- 1 files changed, 16 insertions(+), 13 deletions(-)