X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?p=src%2Fapp-framework-binder.git;a=blobdiff_plain;f=src%2Fjobs.h;h=199a0966dbd9e91b3850a8e9d7837bcc1e31935f;hp=f508e3c052aaf4b413e51d0db3b45adfa54f9f27;hb=65353dce81a629e042800bb7b86fcd869a76727e;hpb=e3a5ff981c25dcb609fe8cc5396a50b81138ee63 diff --git a/src/jobs.h b/src/jobs.h index f508e3c0..199a0966 100644 --- a/src/jobs.h +++ b/src/jobs.h @@ -1,5 +1,5 @@ /* - * Copyright (C) 2016, 2017 "IoT.bzh" + * Copyright (C) 2015-2020 "IoT.bzh" * Author José Bollo * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17,46 +17,47 @@ #pragma once -struct sd_event; struct jobloop; -extern int jobs_queue0( - void *group, - int timeout, - void (*callback)(int signum)); - extern int jobs_queue( - void *group, + const void *group, int timeout, void (*callback)(int signum, void* arg), void *arg); -extern int jobs_queue2( - void *group, +extern int jobs_queue_lazy( + const void *group, int timeout, - void (*callback)(int signum, void* arg1, void *arg2), - void *arg1, - void *arg2); + void (*callback)(int signum, void* arg), + void *arg); -extern int jobs_queue3( - void *group, +extern int jobs_queue_urgent( + const void *group, int timeout, - void (*callback)(int signum, void* arg1, void *arg2, void *arg3), - void *arg1, - void *arg2, - void *arg3); + void (*callback)(int signum, void* arg), + void *arg); extern int jobs_enter( - void *group, + const void *group, int timeout, void (*callback)(int signum, void *closure, struct jobloop *jobloop), void *closure); extern int jobs_leave(struct jobloop *jobloop); -extern struct sd_event *jobs_get_sd_event(); +extern int jobs_call( + const void *group, + int timeout, + void (*callback)(int, void*), + void *arg); -extern void jobs_terminate(); +extern int jobs_start( + int allowed_count, + int start_count, + int waiter_count, + void (*start)(int signum, void* arg), + void *arg); -extern int jobs_start(int allowed_count, int start_count, int waiter_count, void (*start)()); +extern void jobs_acquire_event_manager(); +extern void jobs_exit(void (*handler)());