block: rename BlockAcctType members to start with BLOCK_ instead of BDRV_
The middle term goal is to move the BlockAcctStats structure in the device models. (Capturing I/O accounting statistics in the device models is good for billing) This patch make a small step in this direction by removing a reference to BDRV. CC: Kevin Wolf <kwolf@redhat.com> CC: Stefan Hajnoczi <stefanha@redhat.com> CC: Keith Busch <keith.busch@intel.com> CC: Anthony Liguori <aliguori@amazon.com> CC: "Michael S. Tsirkin" <mst@redhat.com> CC: Paolo Bonzini <pbonzini@redhat.com> CC: John Snow <jsnow@redhat.com> CC: Richard Henderson <rth@twiddle.net> CC: Markus Armbruster <armbru@redhat.com> CC: Alexander Graf <agraf@suse.de>i Signed-off-by: Benoît Canet <benoit.canet@nodalink.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
5e5a94b605
commit
28298fd3d9
@ -29,7 +29,7 @@ void
|
|||||||
bdrv_acct_start(BlockDriverState *bs, BlockAcctCookie *cookie, int64_t bytes,
|
bdrv_acct_start(BlockDriverState *bs, BlockAcctCookie *cookie, int64_t bytes,
|
||||||
enum BlockAcctType type)
|
enum BlockAcctType type)
|
||||||
{
|
{
|
||||||
assert(type < BDRV_MAX_IOTYPE);
|
assert(type < BLOCK_MAX_IOTYPE);
|
||||||
|
|
||||||
cookie->bytes = bytes;
|
cookie->bytes = bytes;
|
||||||
cookie->start_time_ns = get_clock();
|
cookie->start_time_ns = get_clock();
|
||||||
@ -39,7 +39,7 @@ bdrv_acct_start(BlockDriverState *bs, BlockAcctCookie *cookie, int64_t bytes,
|
|||||||
void
|
void
|
||||||
bdrv_acct_done(BlockDriverState *bs, BlockAcctCookie *cookie)
|
bdrv_acct_done(BlockDriverState *bs, BlockAcctCookie *cookie)
|
||||||
{
|
{
|
||||||
assert(cookie->type < BDRV_MAX_IOTYPE);
|
assert(cookie->type < BLOCK_MAX_IOTYPE);
|
||||||
|
|
||||||
bs->stats.nr_bytes[cookie->type] += cookie->bytes;
|
bs->stats.nr_bytes[cookie->type] += cookie->bytes;
|
||||||
bs->stats.nr_ops[cookie->type]++;
|
bs->stats.nr_ops[cookie->type]++;
|
||||||
|
16
block/qapi.c
16
block/qapi.c
@ -333,16 +333,16 @@ static BlockStats *bdrv_query_stats(const BlockDriverState *bs)
|
|||||||
}
|
}
|
||||||
|
|
||||||
s->stats = g_malloc0(sizeof(*s->stats));
|
s->stats = g_malloc0(sizeof(*s->stats));
|
||||||
s->stats->rd_bytes = bs->stats.nr_bytes[BDRV_ACCT_READ];
|
s->stats->rd_bytes = bs->stats.nr_bytes[BLOCK_ACCT_READ];
|
||||||
s->stats->wr_bytes = bs->stats.nr_bytes[BDRV_ACCT_WRITE];
|
s->stats->wr_bytes = bs->stats.nr_bytes[BLOCK_ACCT_WRITE];
|
||||||
s->stats->rd_operations = bs->stats.nr_ops[BDRV_ACCT_READ];
|
s->stats->rd_operations = bs->stats.nr_ops[BLOCK_ACCT_READ];
|
||||||
s->stats->wr_operations = bs->stats.nr_ops[BDRV_ACCT_WRITE];
|
s->stats->wr_operations = bs->stats.nr_ops[BLOCK_ACCT_WRITE];
|
||||||
s->stats->wr_highest_offset =
|
s->stats->wr_highest_offset =
|
||||||
bs->stats.wr_highest_sector * BDRV_SECTOR_SIZE;
|
bs->stats.wr_highest_sector * BDRV_SECTOR_SIZE;
|
||||||
s->stats->flush_operations = bs->stats.nr_ops[BDRV_ACCT_FLUSH];
|
s->stats->flush_operations = bs->stats.nr_ops[BLOCK_ACCT_FLUSH];
|
||||||
s->stats->wr_total_time_ns = bs->stats.total_time_ns[BDRV_ACCT_WRITE];
|
s->stats->wr_total_time_ns = bs->stats.total_time_ns[BLOCK_ACCT_WRITE];
|
||||||
s->stats->rd_total_time_ns = bs->stats.total_time_ns[BDRV_ACCT_READ];
|
s->stats->rd_total_time_ns = bs->stats.total_time_ns[BLOCK_ACCT_READ];
|
||||||
s->stats->flush_total_time_ns = bs->stats.total_time_ns[BDRV_ACCT_FLUSH];
|
s->stats->flush_total_time_ns = bs->stats.total_time_ns[BLOCK_ACCT_FLUSH];
|
||||||
|
|
||||||
if (bs->file) {
|
if (bs->file) {
|
||||||
s->has_parent = true;
|
s->has_parent = true;
|
||||||
|
@ -232,7 +232,7 @@ static uint16_t nvme_rw(NvmeCtrl *n, NvmeNamespace *ns, NvmeCmd *cmd,
|
|||||||
assert((nlb << data_shift) == req->qsg.size);
|
assert((nlb << data_shift) == req->qsg.size);
|
||||||
|
|
||||||
dma_acct_start(n->conf.bs, &req->acct, &req->qsg, is_write ?
|
dma_acct_start(n->conf.bs, &req->acct, &req->qsg, is_write ?
|
||||||
BDRV_ACCT_WRITE : BDRV_ACCT_READ);
|
BLOCK_ACCT_WRITE : BLOCK_ACCT_READ);
|
||||||
req->aiocb = is_write ?
|
req->aiocb = is_write ?
|
||||||
dma_bdrv_write(n->conf.bs, &req->qsg, aio_slba, nvme_rw_cb, req) :
|
dma_bdrv_write(n->conf.bs, &req->qsg, aio_slba, nvme_rw_cb, req) :
|
||||||
dma_bdrv_read(n->conf.bs, &req->qsg, aio_slba, nvme_rw_cb, req);
|
dma_bdrv_read(n->conf.bs, &req->qsg, aio_slba, nvme_rw_cb, req);
|
||||||
|
@ -279,7 +279,7 @@ void virtio_submit_multiwrite(BlockDriverState *bs, MultiReqBuffer *mrb)
|
|||||||
|
|
||||||
static void virtio_blk_handle_flush(VirtIOBlockReq *req, MultiReqBuffer *mrb)
|
static void virtio_blk_handle_flush(VirtIOBlockReq *req, MultiReqBuffer *mrb)
|
||||||
{
|
{
|
||||||
bdrv_acct_start(req->dev->bs, &req->acct, 0, BDRV_ACCT_FLUSH);
|
bdrv_acct_start(req->dev->bs, &req->acct, 0, BLOCK_ACCT_FLUSH);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Make sure all outstanding writes are posted to the backing device.
|
* Make sure all outstanding writes are posted to the backing device.
|
||||||
@ -322,7 +322,7 @@ static void virtio_blk_handle_write(VirtIOBlockReq *req, MultiReqBuffer *mrb)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bdrv_acct_start(req->dev->bs, &req->acct, req->qiov.size, BDRV_ACCT_WRITE);
|
bdrv_acct_start(req->dev->bs, &req->acct, req->qiov.size, BLOCK_ACCT_WRITE);
|
||||||
|
|
||||||
if (mrb->num_writes == 32) {
|
if (mrb->num_writes == 32) {
|
||||||
virtio_submit_multiwrite(req->dev->bs, mrb);
|
virtio_submit_multiwrite(req->dev->bs, mrb);
|
||||||
@ -353,7 +353,7 @@ static void virtio_blk_handle_read(VirtIOBlockReq *req)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bdrv_acct_start(req->dev->bs, &req->acct, req->qiov.size, BDRV_ACCT_READ);
|
bdrv_acct_start(req->dev->bs, &req->acct, req->qiov.size, BLOCK_ACCT_READ);
|
||||||
bdrv_aio_readv(req->dev->bs, sector, &req->qiov,
|
bdrv_aio_readv(req->dev->bs, sector, &req->qiov,
|
||||||
req->qiov.size / BDRV_SECTOR_SIZE,
|
req->qiov.size / BDRV_SECTOR_SIZE,
|
||||||
virtio_blk_rw_complete, req);
|
virtio_blk_rw_complete, req);
|
||||||
|
@ -518,7 +518,8 @@ static int ioreq_runio_qemu_aio(struct ioreq *ioreq)
|
|||||||
|
|
||||||
switch (ioreq->req.operation) {
|
switch (ioreq->req.operation) {
|
||||||
case BLKIF_OP_READ:
|
case BLKIF_OP_READ:
|
||||||
bdrv_acct_start(blkdev->bs, &ioreq->acct, ioreq->v.size, BDRV_ACCT_READ);
|
bdrv_acct_start(blkdev->bs, &ioreq->acct, ioreq->v.size,
|
||||||
|
BLOCK_ACCT_READ);
|
||||||
ioreq->aio_inflight++;
|
ioreq->aio_inflight++;
|
||||||
bdrv_aio_readv(blkdev->bs, ioreq->start / BLOCK_SIZE,
|
bdrv_aio_readv(blkdev->bs, ioreq->start / BLOCK_SIZE,
|
||||||
&ioreq->v, ioreq->v.size / BLOCK_SIZE,
|
&ioreq->v, ioreq->v.size / BLOCK_SIZE,
|
||||||
@ -530,7 +531,8 @@ static int ioreq_runio_qemu_aio(struct ioreq *ioreq)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
bdrv_acct_start(blkdev->bs, &ioreq->acct, ioreq->v.size, BDRV_ACCT_WRITE);
|
bdrv_acct_start(blkdev->bs, &ioreq->acct, ioreq->v.size,
|
||||||
|
BLOCK_ACCT_WRITE);
|
||||||
ioreq->aio_inflight++;
|
ioreq->aio_inflight++;
|
||||||
bdrv_aio_writev(blkdev->bs, ioreq->start / BLOCK_SIZE,
|
bdrv_aio_writev(blkdev->bs, ioreq->start / BLOCK_SIZE,
|
||||||
&ioreq->v, ioreq->v.size / BLOCK_SIZE,
|
&ioreq->v, ioreq->v.size / BLOCK_SIZE,
|
||||||
|
@ -860,7 +860,7 @@ static void process_ncq_command(AHCIState *s, int port, uint8_t *cmd_fis,
|
|||||||
ncq_tfs->tag, ncq_tfs->lba);
|
ncq_tfs->tag, ncq_tfs->lba);
|
||||||
|
|
||||||
dma_acct_start(ncq_tfs->drive->port.ifs[0].bs, &ncq_tfs->acct,
|
dma_acct_start(ncq_tfs->drive->port.ifs[0].bs, &ncq_tfs->acct,
|
||||||
&ncq_tfs->sglist, BDRV_ACCT_READ);
|
&ncq_tfs->sglist, BLOCK_ACCT_READ);
|
||||||
ncq_tfs->aiocb = dma_bdrv_read(ncq_tfs->drive->port.ifs[0].bs,
|
ncq_tfs->aiocb = dma_bdrv_read(ncq_tfs->drive->port.ifs[0].bs,
|
||||||
&ncq_tfs->sglist, ncq_tfs->lba,
|
&ncq_tfs->sglist, ncq_tfs->lba,
|
||||||
ncq_cb, ncq_tfs);
|
ncq_cb, ncq_tfs);
|
||||||
@ -873,7 +873,7 @@ static void process_ncq_command(AHCIState *s, int port, uint8_t *cmd_fis,
|
|||||||
ncq_tfs->tag, ncq_tfs->lba);
|
ncq_tfs->tag, ncq_tfs->lba);
|
||||||
|
|
||||||
dma_acct_start(ncq_tfs->drive->port.ifs[0].bs, &ncq_tfs->acct,
|
dma_acct_start(ncq_tfs->drive->port.ifs[0].bs, &ncq_tfs->acct,
|
||||||
&ncq_tfs->sglist, BDRV_ACCT_WRITE);
|
&ncq_tfs->sglist, BLOCK_ACCT_WRITE);
|
||||||
ncq_tfs->aiocb = dma_bdrv_write(ncq_tfs->drive->port.ifs[0].bs,
|
ncq_tfs->aiocb = dma_bdrv_write(ncq_tfs->drive->port.ifs[0].bs,
|
||||||
&ncq_tfs->sglist, ncq_tfs->lba,
|
&ncq_tfs->sglist, ncq_tfs->lba,
|
||||||
ncq_cb, ncq_tfs);
|
ncq_cb, ncq_tfs);
|
||||||
|
@ -110,12 +110,12 @@ static int cd_read_sector(IDEState *s, int lba, uint8_t *buf, int sector_size)
|
|||||||
|
|
||||||
switch(sector_size) {
|
switch(sector_size) {
|
||||||
case 2048:
|
case 2048:
|
||||||
bdrv_acct_start(s->bs, &s->acct, 4 * BDRV_SECTOR_SIZE, BDRV_ACCT_READ);
|
bdrv_acct_start(s->bs, &s->acct, 4 * BDRV_SECTOR_SIZE, BLOCK_ACCT_READ);
|
||||||
ret = bdrv_read(s->bs, (int64_t)lba << 2, buf, 4);
|
ret = bdrv_read(s->bs, (int64_t)lba << 2, buf, 4);
|
||||||
bdrv_acct_done(s->bs, &s->acct);
|
bdrv_acct_done(s->bs, &s->acct);
|
||||||
break;
|
break;
|
||||||
case 2352:
|
case 2352:
|
||||||
bdrv_acct_start(s->bs, &s->acct, 4 * BDRV_SECTOR_SIZE, BDRV_ACCT_READ);
|
bdrv_acct_start(s->bs, &s->acct, 4 * BDRV_SECTOR_SIZE, BLOCK_ACCT_READ);
|
||||||
ret = bdrv_read(s->bs, (int64_t)lba << 2, buf + 16, 4);
|
ret = bdrv_read(s->bs, (int64_t)lba << 2, buf + 16, 4);
|
||||||
bdrv_acct_done(s->bs, &s->acct);
|
bdrv_acct_done(s->bs, &s->acct);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
@ -253,7 +253,7 @@ static void ide_atapi_cmd_reply(IDEState *s, int size, int max_size)
|
|||||||
s->io_buffer_index = 0;
|
s->io_buffer_index = 0;
|
||||||
|
|
||||||
if (s->atapi_dma) {
|
if (s->atapi_dma) {
|
||||||
bdrv_acct_start(s->bs, &s->acct, size, BDRV_ACCT_READ);
|
bdrv_acct_start(s->bs, &s->acct, size, BLOCK_ACCT_READ);
|
||||||
s->status = READY_STAT | SEEK_STAT | DRQ_STAT;
|
s->status = READY_STAT | SEEK_STAT | DRQ_STAT;
|
||||||
ide_start_dma(s, ide_atapi_cmd_read_dma_cb);
|
ide_start_dma(s, ide_atapi_cmd_read_dma_cb);
|
||||||
} else {
|
} else {
|
||||||
@ -369,7 +369,7 @@ static void ide_atapi_cmd_read_dma(IDEState *s, int lba, int nb_sectors,
|
|||||||
s->io_buffer_size = 0;
|
s->io_buffer_size = 0;
|
||||||
s->cd_sector_size = sector_size;
|
s->cd_sector_size = sector_size;
|
||||||
|
|
||||||
bdrv_acct_start(s->bs, &s->acct, s->packet_transfer_size, BDRV_ACCT_READ);
|
bdrv_acct_start(s->bs, &s->acct, s->packet_transfer_size, BLOCK_ACCT_READ);
|
||||||
|
|
||||||
/* XXX: check if BUSY_STAT should be set */
|
/* XXX: check if BUSY_STAT should be set */
|
||||||
s->status = READY_STAT | SEEK_STAT | DRQ_STAT | BUSY_STAT;
|
s->status = READY_STAT | SEEK_STAT | DRQ_STAT | BUSY_STAT;
|
||||||
|
@ -624,7 +624,7 @@ void ide_sector_read(IDEState *s)
|
|||||||
s->iov.iov_len = n * BDRV_SECTOR_SIZE;
|
s->iov.iov_len = n * BDRV_SECTOR_SIZE;
|
||||||
qemu_iovec_init_external(&s->qiov, &s->iov, 1);
|
qemu_iovec_init_external(&s->qiov, &s->iov, 1);
|
||||||
|
|
||||||
bdrv_acct_start(s->bs, &s->acct, n * BDRV_SECTOR_SIZE, BDRV_ACCT_READ);
|
bdrv_acct_start(s->bs, &s->acct, n * BDRV_SECTOR_SIZE, BLOCK_ACCT_READ);
|
||||||
s->pio_aiocb = bdrv_aio_readv(s->bs, sector_num, &s->qiov, n,
|
s->pio_aiocb = bdrv_aio_readv(s->bs, sector_num, &s->qiov, n,
|
||||||
ide_sector_read_cb, s);
|
ide_sector_read_cb, s);
|
||||||
}
|
}
|
||||||
@ -771,11 +771,11 @@ static void ide_sector_start_dma(IDEState *s, enum ide_dma_cmd dma_cmd)
|
|||||||
switch (dma_cmd) {
|
switch (dma_cmd) {
|
||||||
case IDE_DMA_READ:
|
case IDE_DMA_READ:
|
||||||
bdrv_acct_start(s->bs, &s->acct, s->nsector * BDRV_SECTOR_SIZE,
|
bdrv_acct_start(s->bs, &s->acct, s->nsector * BDRV_SECTOR_SIZE,
|
||||||
BDRV_ACCT_READ);
|
BLOCK_ACCT_READ);
|
||||||
break;
|
break;
|
||||||
case IDE_DMA_WRITE:
|
case IDE_DMA_WRITE:
|
||||||
bdrv_acct_start(s->bs, &s->acct, s->nsector * BDRV_SECTOR_SIZE,
|
bdrv_acct_start(s->bs, &s->acct, s->nsector * BDRV_SECTOR_SIZE,
|
||||||
BDRV_ACCT_WRITE);
|
BLOCK_ACCT_WRITE);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -869,7 +869,7 @@ void ide_sector_write(IDEState *s)
|
|||||||
s->iov.iov_len = n * BDRV_SECTOR_SIZE;
|
s->iov.iov_len = n * BDRV_SECTOR_SIZE;
|
||||||
qemu_iovec_init_external(&s->qiov, &s->iov, 1);
|
qemu_iovec_init_external(&s->qiov, &s->iov, 1);
|
||||||
|
|
||||||
bdrv_acct_start(s->bs, &s->acct, n * BDRV_SECTOR_SIZE, BDRV_ACCT_READ);
|
bdrv_acct_start(s->bs, &s->acct, n * BDRV_SECTOR_SIZE, BLOCK_ACCT_READ);
|
||||||
s->pio_aiocb = bdrv_aio_writev(s->bs, sector_num, &s->qiov, n,
|
s->pio_aiocb = bdrv_aio_writev(s->bs, sector_num, &s->qiov, n,
|
||||||
ide_sector_write_cb, s);
|
ide_sector_write_cb, s);
|
||||||
}
|
}
|
||||||
@ -903,7 +903,7 @@ void ide_flush_cache(IDEState *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
s->status |= BUSY_STAT;
|
s->status |= BUSY_STAT;
|
||||||
bdrv_acct_start(s->bs, &s->acct, 0, BDRV_ACCT_FLUSH);
|
bdrv_acct_start(s->bs, &s->acct, 0, BLOCK_ACCT_FLUSH);
|
||||||
s->pio_aiocb = bdrv_aio_flush(s->bs, ide_flush_cb, s);
|
s->pio_aiocb = bdrv_aio_flush(s->bs, ide_flush_cb, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -371,7 +371,7 @@ static void pmac_ide_transfer(DBDMA_io *io)
|
|||||||
if (s->lba == -1) {
|
if (s->lba == -1) {
|
||||||
s->io_buffer_size = MIN(io->len, s->packet_transfer_size);
|
s->io_buffer_size = MIN(io->len, s->packet_transfer_size);
|
||||||
bdrv_acct_start(s->bs, &s->acct, s->io_buffer_size,
|
bdrv_acct_start(s->bs, &s->acct, s->io_buffer_size,
|
||||||
BDRV_ACCT_READ);
|
BLOCK_ACCT_READ);
|
||||||
MACIO_DPRINTF("non-block ATAPI DMA transfer size: %d\n",
|
MACIO_DPRINTF("non-block ATAPI DMA transfer size: %d\n",
|
||||||
s->io_buffer_size);
|
s->io_buffer_size);
|
||||||
|
|
||||||
@ -387,17 +387,17 @@ static void pmac_ide_transfer(DBDMA_io *io)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bdrv_acct_start(s->bs, &s->acct, io->len, BDRV_ACCT_READ);
|
bdrv_acct_start(s->bs, &s->acct, io->len, BLOCK_ACCT_READ);
|
||||||
pmac_ide_atapi_transfer_cb(io, 0);
|
pmac_ide_atapi_transfer_cb(io, 0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (s->dma_cmd) {
|
switch (s->dma_cmd) {
|
||||||
case IDE_DMA_READ:
|
case IDE_DMA_READ:
|
||||||
bdrv_acct_start(s->bs, &s->acct, io->len, BDRV_ACCT_READ);
|
bdrv_acct_start(s->bs, &s->acct, io->len, BLOCK_ACCT_READ);
|
||||||
break;
|
break;
|
||||||
case IDE_DMA_WRITE:
|
case IDE_DMA_WRITE:
|
||||||
bdrv_acct_start(s->bs, &s->acct, io->len, BDRV_ACCT_WRITE);
|
bdrv_acct_start(s->bs, &s->acct, io->len, BLOCK_ACCT_WRITE);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -237,7 +237,7 @@ static void scsi_write_do_fua(SCSIDiskReq *r)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (scsi_is_cmd_fua(&r->req.cmd)) {
|
if (scsi_is_cmd_fua(&r->req.cmd)) {
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, 0, BDRV_ACCT_FLUSH);
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct, 0, BLOCK_ACCT_FLUSH);
|
||||||
r->req.aiocb = bdrv_aio_flush(s->qdev.conf.bs, scsi_aio_complete, r);
|
r->req.aiocb = bdrv_aio_flush(s->qdev.conf.bs, scsi_aio_complete, r);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -349,13 +349,14 @@ static void scsi_do_read(void *opaque, int ret)
|
|||||||
scsi_req_ref(&r->req);
|
scsi_req_ref(&r->req);
|
||||||
|
|
||||||
if (r->req.sg) {
|
if (r->req.sg) {
|
||||||
dma_acct_start(s->qdev.conf.bs, &r->acct, r->req.sg, BDRV_ACCT_READ);
|
dma_acct_start(s->qdev.conf.bs, &r->acct, r->req.sg, BLOCK_ACCT_READ);
|
||||||
r->req.resid -= r->req.sg->size;
|
r->req.resid -= r->req.sg->size;
|
||||||
r->req.aiocb = dma_bdrv_read(s->qdev.conf.bs, r->req.sg, r->sector,
|
r->req.aiocb = dma_bdrv_read(s->qdev.conf.bs, r->req.sg, r->sector,
|
||||||
scsi_dma_complete, r);
|
scsi_dma_complete, r);
|
||||||
} else {
|
} else {
|
||||||
n = scsi_init_iovec(r, SCSI_DMA_BUF_SIZE);
|
n = scsi_init_iovec(r, SCSI_DMA_BUF_SIZE);
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, n * BDRV_SECTOR_SIZE, BDRV_ACCT_READ);
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct, n * BDRV_SECTOR_SIZE,
|
||||||
|
BLOCK_ACCT_READ);
|
||||||
r->req.aiocb = bdrv_aio_readv(s->qdev.conf.bs, r->sector, &r->qiov, n,
|
r->req.aiocb = bdrv_aio_readv(s->qdev.conf.bs, r->sector, &r->qiov, n,
|
||||||
scsi_read_complete, r);
|
scsi_read_complete, r);
|
||||||
}
|
}
|
||||||
@ -399,7 +400,7 @@ static void scsi_read_data(SCSIRequest *req)
|
|||||||
first = !r->started;
|
first = !r->started;
|
||||||
r->started = true;
|
r->started = true;
|
||||||
if (first && scsi_is_cmd_fua(&r->req.cmd)) {
|
if (first && scsi_is_cmd_fua(&r->req.cmd)) {
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, 0, BDRV_ACCT_FLUSH);
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct, 0, BLOCK_ACCT_FLUSH);
|
||||||
r->req.aiocb = bdrv_aio_flush(s->qdev.conf.bs, scsi_do_read, r);
|
r->req.aiocb = bdrv_aio_flush(s->qdev.conf.bs, scsi_do_read, r);
|
||||||
} else {
|
} else {
|
||||||
scsi_do_read(r, 0);
|
scsi_do_read(r, 0);
|
||||||
@ -522,13 +523,14 @@ static void scsi_write_data(SCSIRequest *req)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (r->req.sg) {
|
if (r->req.sg) {
|
||||||
dma_acct_start(s->qdev.conf.bs, &r->acct, r->req.sg, BDRV_ACCT_WRITE);
|
dma_acct_start(s->qdev.conf.bs, &r->acct, r->req.sg, BLOCK_ACCT_WRITE);
|
||||||
r->req.resid -= r->req.sg->size;
|
r->req.resid -= r->req.sg->size;
|
||||||
r->req.aiocb = dma_bdrv_write(s->qdev.conf.bs, r->req.sg, r->sector,
|
r->req.aiocb = dma_bdrv_write(s->qdev.conf.bs, r->req.sg, r->sector,
|
||||||
scsi_dma_complete, r);
|
scsi_dma_complete, r);
|
||||||
} else {
|
} else {
|
||||||
n = r->qiov.size / 512;
|
n = r->qiov.size / 512;
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, n * BDRV_SECTOR_SIZE, BDRV_ACCT_WRITE);
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct, n * BDRV_SECTOR_SIZE,
|
||||||
|
BLOCK_ACCT_WRITE);
|
||||||
r->req.aiocb = bdrv_aio_writev(s->qdev.conf.bs, r->sector, &r->qiov, n,
|
r->req.aiocb = bdrv_aio_writev(s->qdev.conf.bs, r->sector, &r->qiov, n,
|
||||||
scsi_write_complete, r);
|
scsi_write_complete, r);
|
||||||
}
|
}
|
||||||
@ -1496,7 +1498,7 @@ static void scsi_disk_emulate_mode_select(SCSIDiskReq *r, uint8_t *inbuf)
|
|||||||
if (!bdrv_enable_write_cache(s->qdev.conf.bs)) {
|
if (!bdrv_enable_write_cache(s->qdev.conf.bs)) {
|
||||||
/* The request is used as the AIO opaque value, so add a ref. */
|
/* The request is used as the AIO opaque value, so add a ref. */
|
||||||
scsi_req_ref(&r->req);
|
scsi_req_ref(&r->req);
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, 0, BDRV_ACCT_FLUSH);
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct, 0, BLOCK_ACCT_FLUSH);
|
||||||
r->req.aiocb = bdrv_aio_flush(s->qdev.conf.bs, scsi_aio_complete, r);
|
r->req.aiocb = bdrv_aio_flush(s->qdev.conf.bs, scsi_aio_complete, r);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1662,7 +1664,8 @@ static void scsi_write_same_complete(void *opaque, int ret)
|
|||||||
data->sector += data->iov.iov_len / 512;
|
data->sector += data->iov.iov_len / 512;
|
||||||
data->iov.iov_len = MIN(data->nb_sectors * 512, data->iov.iov_len);
|
data->iov.iov_len = MIN(data->nb_sectors * 512, data->iov.iov_len);
|
||||||
if (data->iov.iov_len) {
|
if (data->iov.iov_len) {
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, data->iov.iov_len, BDRV_ACCT_WRITE);
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct, data->iov.iov_len,
|
||||||
|
BLOCK_ACCT_WRITE);
|
||||||
r->req.aiocb = bdrv_aio_writev(s->qdev.conf.bs, data->sector,
|
r->req.aiocb = bdrv_aio_writev(s->qdev.conf.bs, data->sector,
|
||||||
&data->qiov, data->iov.iov_len / 512,
|
&data->qiov, data->iov.iov_len / 512,
|
||||||
scsi_write_same_complete, data);
|
scsi_write_same_complete, data);
|
||||||
@ -1708,8 +1711,8 @@ static void scsi_disk_emulate_write_same(SCSIDiskReq *r, uint8_t *inbuf)
|
|||||||
|
|
||||||
/* The request is used as the AIO opaque value, so add a ref. */
|
/* The request is used as the AIO opaque value, so add a ref. */
|
||||||
scsi_req_ref(&r->req);
|
scsi_req_ref(&r->req);
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, nb_sectors * s->qdev.blocksize,
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct,
|
||||||
BDRV_ACCT_WRITE);
|
nb_sectors * s->qdev.blocksize, BLOCK_ACCT_WRITE);
|
||||||
r->req.aiocb = bdrv_aio_write_zeroes(s->qdev.conf.bs,
|
r->req.aiocb = bdrv_aio_write_zeroes(s->qdev.conf.bs,
|
||||||
r->req.cmd.lba * (s->qdev.blocksize / 512),
|
r->req.cmd.lba * (s->qdev.blocksize / 512),
|
||||||
nb_sectors * (s->qdev.blocksize / 512),
|
nb_sectors * (s->qdev.blocksize / 512),
|
||||||
@ -1730,7 +1733,8 @@ static void scsi_disk_emulate_write_same(SCSIDiskReq *r, uint8_t *inbuf)
|
|||||||
}
|
}
|
||||||
|
|
||||||
scsi_req_ref(&r->req);
|
scsi_req_ref(&r->req);
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, data->iov.iov_len, BDRV_ACCT_WRITE);
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct, data->iov.iov_len,
|
||||||
|
BLOCK_ACCT_WRITE);
|
||||||
r->req.aiocb = bdrv_aio_writev(s->qdev.conf.bs, data->sector,
|
r->req.aiocb = bdrv_aio_writev(s->qdev.conf.bs, data->sector,
|
||||||
&data->qiov, data->iov.iov_len / 512,
|
&data->qiov, data->iov.iov_len / 512,
|
||||||
scsi_write_same_complete, data);
|
scsi_write_same_complete, data);
|
||||||
@ -1994,7 +1998,7 @@ static int32_t scsi_disk_emulate_command(SCSIRequest *req, uint8_t *buf)
|
|||||||
case SYNCHRONIZE_CACHE:
|
case SYNCHRONIZE_CACHE:
|
||||||
/* The request is used as the AIO opaque value, so add a ref. */
|
/* The request is used as the AIO opaque value, so add a ref. */
|
||||||
scsi_req_ref(&r->req);
|
scsi_req_ref(&r->req);
|
||||||
bdrv_acct_start(s->qdev.conf.bs, &r->acct, 0, BDRV_ACCT_FLUSH);
|
bdrv_acct_start(s->qdev.conf.bs, &r->acct, 0, BLOCK_ACCT_FLUSH);
|
||||||
r->req.aiocb = bdrv_aio_flush(s->qdev.conf.bs, scsi_aio_complete, r);
|
r->req.aiocb = bdrv_aio_flush(s->qdev.conf.bs, scsi_aio_complete, r);
|
||||||
return 0;
|
return 0;
|
||||||
case SEEK_10:
|
case SEEK_10:
|
||||||
|
@ -29,16 +29,16 @@
|
|||||||
#include "qemu/typedefs.h"
|
#include "qemu/typedefs.h"
|
||||||
|
|
||||||
enum BlockAcctType {
|
enum BlockAcctType {
|
||||||
BDRV_ACCT_READ,
|
BLOCK_ACCT_READ,
|
||||||
BDRV_ACCT_WRITE,
|
BLOCK_ACCT_WRITE,
|
||||||
BDRV_ACCT_FLUSH,
|
BLOCK_ACCT_FLUSH,
|
||||||
BDRV_MAX_IOTYPE,
|
BLOCK_MAX_IOTYPE,
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct BlockAcctStats {
|
typedef struct BlockAcctStats {
|
||||||
uint64_t nr_bytes[BDRV_MAX_IOTYPE];
|
uint64_t nr_bytes[BLOCK_MAX_IOTYPE];
|
||||||
uint64_t nr_ops[BDRV_MAX_IOTYPE];
|
uint64_t nr_ops[BLOCK_MAX_IOTYPE];
|
||||||
uint64_t total_time_ns[BDRV_MAX_IOTYPE];
|
uint64_t total_time_ns[BLOCK_MAX_IOTYPE];
|
||||||
uint64_t wr_highest_sector;
|
uint64_t wr_highest_sector;
|
||||||
} BlockAcctStats;
|
} BlockAcctStats;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user