|
@@ -120,8 +120,8 @@ static void pmac_dma_read(BlockBackend *blk,
|
|
|
MACIO_DPRINTF("--- Block read transfer - sector_num: %" PRIx64 " "
|
|
|
"nsector: %x\n", (offset >> 9), (bytes >> 9));
|
|
|
|
|
|
- m->aiocb = blk_aio_readv(blk, (offset >> 9), &io->iov, (bytes >> 9),
|
|
|
- cb, io);
|
|
|
+ s->bus->dma->aiocb = blk_aio_readv(blk, (offset >> 9), &io->iov,
|
|
|
+ (bytes >> 9), cb, io);
|
|
|
}
|
|
|
|
|
|
static void pmac_dma_write(BlockBackend *blk,
|
|
@@ -205,8 +205,8 @@ static void pmac_dma_write(BlockBackend *blk,
|
|
|
MACIO_DPRINTF("--- Block write transfer - sector_num: %" PRIx64 " "
|
|
|
"nsector: %x\n", (offset >> 9), (bytes >> 9));
|
|
|
|
|
|
- m->aiocb = blk_aio_writev(blk, (offset >> 9), &io->iov, (bytes >> 9),
|
|
|
- cb, io);
|
|
|
+ s->bus->dma->aiocb = blk_aio_writev(blk, (offset >> 9), &io->iov,
|
|
|
+ (bytes >> 9), cb, io);
|
|
|
}
|
|
|
|
|
|
static void pmac_dma_trim(BlockBackend *blk,
|
|
@@ -232,8 +232,8 @@ static void pmac_dma_trim(BlockBackend *blk,
|
|
|
s->io_buffer_index += io->len;
|
|
|
io->len = 0;
|
|
|
|
|
|
- m->aiocb = ide_issue_trim(blk, (offset >> 9), &io->iov, (bytes >> 9),
|
|
|
- cb, io);
|
|
|
+ s->bus->dma->aiocb = ide_issue_trim(blk, (offset >> 9), &io->iov,
|
|
|
+ (bytes >> 9), cb, io);
|
|
|
}
|
|
|
|
|
|
static void pmac_ide_atapi_transfer_cb(void *opaque, int ret)
|
|
@@ -292,6 +292,8 @@ done:
|
|
|
} else {
|
|
|
block_acct_done(blk_get_stats(s->blk), &s->acct);
|
|
|
}
|
|
|
+
|
|
|
+ ide_set_inactive(s, false);
|
|
|
io->dma_end(opaque);
|
|
|
}
|
|
|
|
|
@@ -306,7 +308,6 @@ static void pmac_ide_transfer_cb(void *opaque, int ret)
|
|
|
|
|
|
if (ret < 0) {
|
|
|
MACIO_DPRINTF("DMA error: %d\n", ret);
|
|
|
- m->aiocb = NULL;
|
|
|
ide_dma_error(s);
|
|
|
goto done;
|
|
|
}
|
|
@@ -357,6 +358,8 @@ done:
|
|
|
block_acct_done(blk_get_stats(s->blk), &s->acct);
|
|
|
}
|
|
|
}
|
|
|
+
|
|
|
+ ide_set_inactive(s, false);
|
|
|
io->dma_end(opaque);
|
|
|
}
|
|
|
|
|
@@ -394,8 +397,9 @@ static void pmac_ide_transfer(DBDMA_io *io)
|
|
|
static void pmac_ide_flush(DBDMA_io *io)
|
|
|
{
|
|
|
MACIOIDEState *m = io->opaque;
|
|
|
+ IDEState *s = idebus_active_if(&m->bus);
|
|
|
|
|
|
- if (m->aiocb) {
|
|
|
+ if (s->bus->dma->aiocb) {
|
|
|
blk_drain_all();
|
|
|
}
|
|
|
}
|