提交 2f0772c5 编写于 作者: P Paolo Bonzini

lsi: use qdev_reset_all

By first resetting the devices, lsi_soft_reset will find the queue
already cleared so there is no need to do that forcibly (which may also
leak SCSIRequests, and/or worse due to dangling references to the
lsi_request in the hba_private field).
Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
上级 e2b06058
...@@ -282,8 +282,6 @@ static inline int lsi_irq_on_rsl(LSIState *s) ...@@ -282,8 +282,6 @@ static inline int lsi_irq_on_rsl(LSIState *s)
static void lsi_soft_reset(LSIState *s) static void lsi_soft_reset(LSIState *s)
{ {
lsi_request *p;
DPRINTF("Reset\n"); DPRINTF("Reset\n");
s->carry = 0; s->carry = 0;
...@@ -350,15 +348,8 @@ static void lsi_soft_reset(LSIState *s) ...@@ -350,15 +348,8 @@ static void lsi_soft_reset(LSIState *s)
s->sbc = 0; s->sbc = 0;
s->csbc = 0; s->csbc = 0;
s->sbr = 0; s->sbr = 0;
while (!QTAILQ_EMPTY(&s->queue)) { assert(QTAILQ_EMPTY(&s->queue));
p = QTAILQ_FIRST(&s->queue); assert(!s->current);
QTAILQ_REMOVE(&s->queue, p, next);
g_free(p);
}
if (s->current) {
g_free(s->current);
s->current = NULL;
}
} }
static int lsi_dma_40bit(LSIState *s) static int lsi_dma_40bit(LSIState *s)
...@@ -1738,7 +1729,7 @@ static void lsi_reg_writeb(LSIState *s, int offset, uint8_t val) ...@@ -1738,7 +1729,7 @@ static void lsi_reg_writeb(LSIState *s, int offset, uint8_t val)
lsi_execute_script(s); lsi_execute_script(s);
} }
if (val & LSI_ISTAT0_SRST) { if (val & LSI_ISTAT0_SRST) {
lsi_soft_reset(s); qdev_reset_all(&s->dev.qdev);
} }
break; break;
case 0x16: /* MBOX0 */ case 0x16: /* MBOX0 */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册