macio: fix NULL pointer dereference when issuing IDE trim
authorMark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
Tue, 27 Mar 2018 04:38:00 +0000 (00:38 -0400)
committerJohn Snow <jsnow@redhat.com>
Tue, 27 Mar 2018 04:38:00 +0000 (00:38 -0400)
Commit ef0e64a983 "ide: pass IDEState to trim AIO callback" changed the
IDE trim callback from using a BlockBackend to an IDEState but forgot to update
the dma_blk_io() call in hw/ide/macio.c accordingly.

Without this fix qemu-system-ppc segfaults when issuing an IDE trim command on
any of the PPC Mac machines (easily triggered by running the Debian installer).

Reported-by: Howard Spoelstra <hsp.cat7@gmail.com>
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
Reviewed-by: Anton Nefedov <anton.nefedov@virtuozzo.com>
Message-id: 20180223184700.28854-1-mark.cave-ayland@ilande.co.uk
Signed-off-by: John Snow <jsnow@redhat.com>
hw/ide/macio.c

index 2e043ef1ea8ce583c478a70c8787dc791331b9fd..d3a85cba3b3615b4692a86af21baecff2fc5522f 100644 (file)
@@ -187,7 +187,7 @@ static void pmac_ide_transfer_cb(void *opaque, int ret)
         break;
     case IDE_DMA_TRIM:
         s->bus->dma->aiocb = dma_blk_io(blk_get_aio_context(s->blk), &s->sg,
-                                        offset, 0x1, ide_issue_trim, s->blk,
+                                        offset, 0x1, ide_issue_trim, s,
                                         pmac_ide_transfer_cb, io,
                                         DMA_DIRECTION_TO_DEVICE);
         break;
This page took 0.02328 seconds and 4 git commands to generate.