Initial version.
This commit is contained in:
87
src/nxt_job.h
Normal file
87
src/nxt_job.h
Normal file
@@ -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_ */
|
||||
Reference in New Issue
Block a user