mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-27 20:13:08 -06:00
quorum: Avoid bdrv_aio_writev() for rewrites
Replacing it with bdrv_co_pwritev() prepares us for byte granularity requests and gets us rid of the last bdrv_aio_*() user in quorum. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Alberto Garcia <berto@igalia.com> Reviewed-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
parent
7cd9b3964e
commit
dee66e2882
1 changed files with 31 additions and 15 deletions
|
@ -221,15 +221,6 @@ static bool quorum_has_too_much_io_failed(QuorumAIOCB *acb)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void quorum_rewrite_aio_cb(void *opaque, int ret)
|
|
||||||
{
|
|
||||||
QuorumAIOCB *acb = opaque;
|
|
||||||
|
|
||||||
/* one less rewrite to do */
|
|
||||||
acb->rewrite_count--;
|
|
||||||
qemu_coroutine_enter_if_inactive(acb->co);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int read_fifo_child(QuorumAIOCB *acb);
|
static int read_fifo_child(QuorumAIOCB *acb);
|
||||||
|
|
||||||
static void quorum_copy_qiov(QEMUIOVector *dest, QEMUIOVector *source)
|
static void quorum_copy_qiov(QEMUIOVector *dest, QEMUIOVector *source)
|
||||||
|
@ -296,7 +287,27 @@ static void quorum_report_bad_versions(BDRVQuorumState *s,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool quorum_rewrite_bad_versions(BDRVQuorumState *s, QuorumAIOCB *acb,
|
static void quorum_rewrite_entry(void *opaque)
|
||||||
|
{
|
||||||
|
QuorumCo *co = opaque;
|
||||||
|
QuorumAIOCB *acb = co->acb;
|
||||||
|
BDRVQuorumState *s = acb->bs->opaque;
|
||||||
|
|
||||||
|
/* Ignore any errors, it's just a correction attempt for already
|
||||||
|
* corrupted data. */
|
||||||
|
bdrv_co_pwritev(s->children[co->idx],
|
||||||
|
acb->sector_num * BDRV_SECTOR_SIZE,
|
||||||
|
acb->nb_sectors * BDRV_SECTOR_SIZE,
|
||||||
|
acb->qiov, 0);
|
||||||
|
|
||||||
|
/* Wake up the caller after the last rewrite */
|
||||||
|
acb->rewrite_count--;
|
||||||
|
if (!acb->rewrite_count) {
|
||||||
|
qemu_coroutine_enter_if_inactive(acb->co);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool quorum_rewrite_bad_versions(QuorumAIOCB *acb,
|
||||||
QuorumVoteValue *value)
|
QuorumVoteValue *value)
|
||||||
{
|
{
|
||||||
QuorumVoteVersion *version;
|
QuorumVoteVersion *version;
|
||||||
|
@ -315,7 +326,7 @@ static bool quorum_rewrite_bad_versions(BDRVQuorumState *s, QuorumAIOCB *acb,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* quorum_rewrite_aio_cb will count down this to zero */
|
/* quorum_rewrite_entry will count down this to zero */
|
||||||
acb->rewrite_count = count;
|
acb->rewrite_count = count;
|
||||||
|
|
||||||
/* now fire the correcting rewrites */
|
/* now fire the correcting rewrites */
|
||||||
|
@ -324,9 +335,14 @@ static bool quorum_rewrite_bad_versions(BDRVQuorumState *s, QuorumAIOCB *acb,
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
QLIST_FOREACH(item, &version->items, next) {
|
QLIST_FOREACH(item, &version->items, next) {
|
||||||
bdrv_aio_writev(s->children[item->index], acb->sector_num,
|
Coroutine *co;
|
||||||
acb->qiov, acb->nb_sectors, quorum_rewrite_aio_cb,
|
QuorumCo data = {
|
||||||
acb);
|
.acb = acb,
|
||||||
|
.idx = item->index,
|
||||||
|
};
|
||||||
|
|
||||||
|
co = qemu_coroutine_create(quorum_rewrite_entry, &data);
|
||||||
|
qemu_coroutine_enter(co);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -579,7 +595,7 @@ static void quorum_vote(QuorumAIOCB *acb)
|
||||||
|
|
||||||
/* corruption correction is enabled */
|
/* corruption correction is enabled */
|
||||||
if (s->rewrite_corrupted) {
|
if (s->rewrite_corrupted) {
|
||||||
quorum_rewrite_bad_versions(s, acb, &winner->value);
|
quorum_rewrite_bad_versions(acb, &winner->value);
|
||||||
}
|
}
|
||||||
|
|
||||||
free_exit:
|
free_exit:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue