X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;ds=sidebyside;f=job-qmp.c;h=fbfed25a00067c5035bfde3d7b89c4754527159a;hb=c4107e8208d0222f9b328691b519aaee4101db87;hp=b2e18cfd9c19827aa40f94d8f583d49da235ca6c;hpb=1a90bc8128ee7d16ce4abb131961e37084d75b16;p=mirror_qemu.git diff --git a/job-qmp.c b/job-qmp.c index b2e18cfd9c..fbfed25a00 100644 --- a/job-qmp.c +++ b/job-qmp.c @@ -24,7 +24,6 @@ */ #include "qemu/osdep.h" -#include "qemu-common.h" #include "qemu/job.h" #include "qapi/qapi-commands-job.h" #include "qapi/error.h" @@ -132,3 +131,53 @@ void qmp_job_dismiss(const char *id, Error **errp) job_dismiss(&job, errp); aio_context_release(aio_context); } + +static JobInfo *job_query_single(Job *job, Error **errp) +{ + JobInfo *info; + + assert(!job_is_internal(job)); + + info = g_new(JobInfo, 1); + *info = (JobInfo) { + .id = g_strdup(job->id), + .type = job_type(job), + .status = job->status, + .current_progress = job->progress_current, + .total_progress = job->progress_total, + .has_error = !!job->err, + .error = job->err ? \ + g_strdup(error_get_pretty(job->err)) : NULL, + }; + + return info; +} + +JobInfoList *qmp_query_jobs(Error **errp) +{ + JobInfoList *head = NULL, **p_next = &head; + Job *job; + + for (job = job_next(NULL); job; job = job_next(job)) { + JobInfoList *elem; + AioContext *aio_context; + + if (job_is_internal(job)) { + continue; + } + elem = g_new0(JobInfoList, 1); + aio_context = job->aio_context; + aio_context_acquire(aio_context); + elem->value = job_query_single(job, errp); + aio_context_release(aio_context); + if (!elem->value) { + g_free(elem); + qapi_free_JobInfoList(head); + return NULL; + } + *p_next = elem; + p_next = &elem->next; + } + + return head; +}