diff options
Diffstat (limited to '')
-rw-r--r-- | src/nxt_job.h | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/src/nxt_job.h b/src/nxt_job.h new file mode 100644 index 00000000..320716ca --- /dev/null +++ b/src/nxt_job.h @@ -0,0 +1,87 @@ + +/* + * Copyright (C) Igor Sysoev + * Copyright (C) NGINX, Inc. + */ + +#ifndef _NXT_JOB_H_INCLUDED_ +#define _NXT_JOB_H_INCLUDED_ + + +/* + * A job may run by separate thread, so each job should have its + * its own mem_pool. A job itself is allocated from this mem_pool. + * On job completion a job initiator can destroy the job at once + * with nxt_job_destroy() or can postpone the destruction with + * nxt_job_cleanup_add(), if the initiator uses data from the job's + * mem_pool. + * + * Several child jobs may run in context of another job in the same + * thread. In this case the child job may use a mem_pool of the + * parent job and the child job is allocated using the mem_pool's cache. + * nxt_job_destroy() just returns the job to the cache. All job + * allocations however still remain in the parent mem_pool. + * + * The first thread in job thread pool is created on demand. If this + * operation fails the job abort handler is called. It also is called + * if the job is canceled. To avoid race condition the abort handler + * always runs in context of a thread initiated the job. The abort + * handler may be as simple as nxt_job_destroy(). + */ + + +typedef struct { + void *data; + + nxt_work_handler_t abort_handler; + + uint16_t cache_size; + uint8_t cancel; /* 1 bit */ + + nxt_mem_pool_t *mem_pool; + nxt_queue_link_t link; + +#if (NXT_THREADS) + nxt_thread_pool_t *thread_pool; + nxt_event_engine_t *engine; + nxt_log_t *log; +#endif + +#if (NXT_DEBUG) + const char *name; +#endif + +} nxt_job_t; + + +NXT_EXPORT void *nxt_job_create(nxt_mem_pool_t *mp, size_t size); +NXT_EXPORT void nxt_job_init(nxt_job_t *job, size_t size); +NXT_EXPORT void nxt_job_destroy(void *data); +NXT_EXPORT nxt_int_t nxt_job_cleanup_add(nxt_mem_pool_t *mp, nxt_job_t *job); + +NXT_EXPORT void nxt_job_start(nxt_thread_t *thr, nxt_job_t *job, + nxt_work_handler_t handler); +NXT_EXPORT void nxt_job_return(nxt_thread_t *thr, nxt_job_t *job, + nxt_work_handler_t handler); + + +#define \ +nxt_job_cancel(job) \ + (job)->cancel = 1 + + +#if (NXT_DEBUG) + +#define \ +nxt_job_set_name(job, text) \ + (job)->name = text + +#else + +#define \ +nxt_job_set_name(job, text) + +#endif + + +#endif /* _NXT_JOB_H_INCLUDED_ */ |