mirror of
https://github.com/qemu/qemu.git
synced 2024-11-23 19:03:38 +08:00
coroutine: Drop co_sleep_ns
block_job_sleep_ns is the only user. Since we are moving towards AioContext aware code, it's better to use the explicit version and drop the old one. Signed-off-by: Fam Zheng <famz@redhat.com> Reviewed-by: Benoît Canet <benoit.canet@nodalink.com> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
parent
a9db86b223
commit
0b9caf9b31
@ -205,7 +205,7 @@ void block_job_sleep_ns(BlockJob *job, QEMUClockType type, int64_t ns)
|
||||
if (block_job_is_paused(job)) {
|
||||
qemu_coroutine_yield();
|
||||
} else {
|
||||
co_sleep_ns(type, ns);
|
||||
co_aio_sleep_ns(bdrv_get_aio_context(job->bs), type, ns);
|
||||
}
|
||||
job->busy = true;
|
||||
}
|
||||
|
@ -200,14 +200,6 @@ void qemu_co_rwlock_wrlock(CoRwlock *lock);
|
||||
*/
|
||||
void qemu_co_rwlock_unlock(CoRwlock *lock);
|
||||
|
||||
/**
|
||||
* Yield the coroutine for a given duration
|
||||
*
|
||||
* Note this function uses timers and hence only works when a main loop is in
|
||||
* use. See main-loop.h and do not use from qemu-tool programs.
|
||||
*/
|
||||
void coroutine_fn co_sleep_ns(QEMUClockType type, int64_t ns);
|
||||
|
||||
/**
|
||||
* Yield the coroutine for a given duration
|
||||
*
|
||||
|
@ -27,18 +27,6 @@ static void co_sleep_cb(void *opaque)
|
||||
qemu_coroutine_enter(sleep_cb->co, NULL);
|
||||
}
|
||||
|
||||
void coroutine_fn co_sleep_ns(QEMUClockType type, int64_t ns)
|
||||
{
|
||||
CoSleepCB sleep_cb = {
|
||||
.co = qemu_coroutine_self(),
|
||||
};
|
||||
sleep_cb.ts = timer_new(type, SCALE_NS, co_sleep_cb, &sleep_cb);
|
||||
timer_mod(sleep_cb.ts, qemu_clock_get_ns(type) + ns);
|
||||
qemu_coroutine_yield();
|
||||
timer_del(sleep_cb.ts);
|
||||
timer_free(sleep_cb.ts);
|
||||
}
|
||||
|
||||
void coroutine_fn co_aio_sleep_ns(AioContext *ctx, QEMUClockType type,
|
||||
int64_t ns)
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user