X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fjobs.h;h=44304ede17ae7c1a4ba388904e3d07c23820d4a0;hb=0ea0734fa3f304af325b4a0429bb0cfaabeeed96;hp=f508e3c052aaf4b413e51d0db3b45adfa54f9f27;hpb=e3a5ff981c25dcb609fe8cc5396a50b81138ee63;p=src%2Fapp-framework-binder.git diff --git a/src/jobs.h b/src/jobs.h index f508e3c0..44304ede 100644 --- a/src/jobs.h +++ b/src/jobs.h @@ -1,5 +1,5 @@ /* - * Copyright (C) 2016, 2017 "IoT.bzh" + * Copyright (C) 2016-2019 "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)());