e2c1c34f13
We have two inclusion loops:
block/block.h
-> block/block-global-state.h
-> block/block-common.h
-> block/blockjob.h
-> block/block.h
block/block.h
-> block/block-io.h
-> block/block-common.h
-> block/blockjob.h
-> block/block.h
I believe these go back to Emanuele's reorganization of the block API,
merged a few months ago in commit d7e2fe4aac
.
Fortunately, breaking them is merely a matter of deleting unnecessary
includes from headers, and adding them back in places where they are
now missing.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Message-Id: <20221221133551.3967339-2-armbru@redhat.com>
41 lines
1.1 KiB
C
41 lines
1.1 KiB
C
/*
|
|
* QEMU block layer thread pool
|
|
*
|
|
* Copyright IBM, Corp. 2008
|
|
* Copyright Red Hat, Inc. 2012
|
|
*
|
|
* Authors:
|
|
* Anthony Liguori <aliguori@us.ibm.com>
|
|
* Paolo Bonzini <pbonzini@redhat.com>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2. See
|
|
* the COPYING file in the top-level directory.
|
|
*
|
|
* Contributions after 2012-01-13 are licensed under the terms of the
|
|
* GNU GPL, version 2 or (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef QEMU_THREAD_POOL_H
|
|
#define QEMU_THREAD_POOL_H
|
|
|
|
#include "block/aio.h"
|
|
|
|
#define THREAD_POOL_MAX_THREADS_DEFAULT 64
|
|
|
|
typedef int ThreadPoolFunc(void *opaque);
|
|
|
|
typedef struct ThreadPool ThreadPool;
|
|
|
|
ThreadPool *thread_pool_new(struct AioContext *ctx);
|
|
void thread_pool_free(ThreadPool *pool);
|
|
|
|
BlockAIOCB *thread_pool_submit_aio(ThreadPool *pool,
|
|
ThreadPoolFunc *func, void *arg,
|
|
BlockCompletionFunc *cb, void *opaque);
|
|
int coroutine_fn thread_pool_submit_co(ThreadPool *pool,
|
|
ThreadPoolFunc *func, void *arg);
|
|
void thread_pool_submit(ThreadPool *pool, ThreadPoolFunc *func, void *arg);
|
|
void thread_pool_update_params(ThreadPool *pool, struct AioContext *ctx);
|
|
|
|
#endif
|