comparison mupdf-source/thirdparty/openjpeg/src/lib/openjp2/thread.h @ 2:b50eed0cc0ef upstream

ADD: MuPDF v1.26.7: the MuPDF source as downloaded by a default build of PyMuPDF 1.26.4. The directory name has changed: no version number in the expanded directory now.
author Franz Glasner <fzglas.hg@dom66.de>
date Mon, 15 Sep 2025 11:43:07 +0200
parents
children
comparison
equal deleted inserted replaced
1:1d09e1dec1d9 2:b50eed0cc0ef
1 /*
2 * The copyright in this software is being made available under the 2-clauses
3 * BSD License, included below. This software may be subject to other third
4 * party and contributor rights, including patent rights, and no such rights
5 * are granted under this license.
6 *
7 * Copyright (c) 2016, Even Rouault
8 * All rights reserved.
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
20 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
23 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
30 */
31
32 #ifndef THREAD_H
33 #define THREAD_H
34
35 #include "openjpeg.h"
36
37 /**
38 @file thread.h
39 @brief Thread API
40
41 The functions in thread.c have for goal to manage mutex, conditions, thread
42 creation and thread pools that accept jobs.
43 */
44
45 /** @defgroup THREAD THREAD - Mutex, conditions, threads and thread pools */
46 /*@{*/
47
48 /** @name Mutex */
49 /*@{*/
50
51 /** Opaque type for a mutex */
52 typedef struct opj_mutex_t opj_mutex_t;
53
54 /** Creates a mutex.
55 * @return the mutex or NULL in case of error (can for example happen if the library
56 * is built without thread support)
57 */
58 opj_mutex_t* opj_mutex_create(void);
59
60 /** Lock/acquire the mutex.
61 * @param mutex the mutex to acquire.
62 */
63 void opj_mutex_lock(opj_mutex_t* mutex);
64
65 /** Unlock/release the mutex.
66 * @param mutex the mutex to release.
67 */
68 void opj_mutex_unlock(opj_mutex_t* mutex);
69
70 /** Destroy a mutex
71 * @param mutex the mutex to destroy.
72 */
73 void opj_mutex_destroy(opj_mutex_t* mutex);
74
75 /*@}*/
76
77 /** @name Condition */
78 /*@{*/
79
80 /** Opaque type for a condition */
81 typedef struct opj_cond_t opj_cond_t;
82
83 /** Creates a condition.
84 * @return the condition or NULL in case of error (can for example happen if the library
85 * is built without thread support)
86 */
87 opj_cond_t* opj_cond_create(void);
88
89 /** Wait for the condition to be signaled.
90 * The semantics is the same as the POSIX pthread_cond_wait.
91 * The provided mutex *must* be acquired before calling this function, and
92 * released afterwards.
93 * The mutex will be released by this function while it must wait for the condition
94 * and reacquired afterwards.
95 * In some particular situations, the function might return even if the condition is not signaled
96 * with opj_cond_signal(), hence the need to check with an application level
97 * mechanism.
98 *
99 * Waiting thread :
100 * \code
101 * opj_mutex_lock(mutex);
102 * while( !some_application_level_condition )
103 * {
104 * opj_cond_wait(cond, mutex);
105 * }
106 * opj_mutex_unlock(mutex);
107 * \endcode
108 *
109 * Signaling thread :
110 * \code
111 * opj_mutex_lock(mutex);
112 * some_application_level_condition = TRUE;
113 * opj_cond_signal(cond);
114 * opj_mutex_unlock(mutex);
115 * \endcode
116 *
117 * @param cond the condition to wait.
118 * @param mutex the mutex (in acquired state before calling this function)
119 */
120 void opj_cond_wait(opj_cond_t* cond, opj_mutex_t* mutex);
121
122 /** Signal waiting threads on a condition.
123 * One of the thread waiting with opj_cond_wait() will be waken up.
124 * It is strongly advised that this call is done with the mutex that is used
125 * by opj_cond_wait(), in a acquired state.
126 * @param cond the condition to signal.
127 */
128 void opj_cond_signal(opj_cond_t* cond);
129
130 /** Destroy a condition
131 * @param cond the condition to destroy.
132 */
133 void opj_cond_destroy(opj_cond_t* cond);
134
135 /*@}*/
136
137 /** @name Thread */
138 /*@{*/
139
140 /** Opaque type for a thread handle */
141 typedef struct opj_thread_t opj_thread_t;
142
143 /** User function to execute in a thread
144 * @param user_data user data provided with opj_thread_create()
145 */
146 typedef void (*opj_thread_fn)(void* user_data);
147
148 /** Creates a new thread.
149 * @param thread_fn Function to run in the new thread.
150 * @param user_data user data provided to the thread function. Might be NULL.
151 * @return a thread handle or NULL in case of failure (can for example happen if the library
152 * is built without thread support)
153 */
154 opj_thread_t* opj_thread_create(opj_thread_fn thread_fn, void* user_data);
155
156 /** Wait for a thread to be finished and release associated resources to the
157 * thread handle.
158 * @param thread the thread to wait for being finished.
159 */
160 void opj_thread_join(opj_thread_t* thread);
161
162 /*@}*/
163
164 /** @name Thread local storage */
165 /*@{*/
166 /** Opaque type for a thread local storage */
167 typedef struct opj_tls_t opj_tls_t;
168
169 /** Get a thread local value corresponding to the provided key.
170 * @param tls thread local storage handle
171 * @param key key whose value to retrieve.
172 * @return value associated with the key, or NULL is missing.
173 */
174 void* opj_tls_get(opj_tls_t* tls, int key);
175
176 /** Type of the function used to free a TLS value */
177 typedef void (*opj_tls_free_func)(void* value);
178
179 /** Set a thread local value corresponding to the provided key.
180 * @param tls thread local storage handle
181 * @param key key whose value to set.
182 * @param value value to set (may be NULL).
183 * @param free_func function to call currently installed value.
184 * @return OPJ_TRUE if successful.
185 */
186 OPJ_BOOL opj_tls_set(opj_tls_t* tls, int key, void* value,
187 opj_tls_free_func free_func);
188
189 /*@}*/
190
191 /** @name Thread pool */
192 /*@{*/
193
194 /** Opaque type for a thread pool */
195 typedef struct opj_thread_pool_t opj_thread_pool_t;
196
197 /** Create a new thread pool.
198 * num_thread must nominally be >= 1 to create a real thread pool. If num_threads
199 * is negative or null, then a dummy thread pool will be created. All functions
200 * operating on the thread pool will work, but job submission will be run
201 * synchronously in the calling thread.
202 *
203 * @param num_threads the number of threads to allocate for this thread pool.
204 * @return a thread pool handle, or NULL in case of failure (can for example happen if the library
205 * is built without thread support)
206 */
207 opj_thread_pool_t* opj_thread_pool_create(int num_threads);
208
209 /** User function to execute in a thread
210 * @param user_data user data provided with opj_thread_create()
211 * @param tls handle to thread local storage
212 */
213 typedef void (*opj_job_fn)(void* user_data, opj_tls_t* tls);
214
215
216 /** Submit a new job to be run by one of the thread in the thread pool.
217 * The job ( thread_fn, user_data ) will be added in the queue of jobs managed
218 * by the thread pool, and run by the first thread that is no longer busy.
219 *
220 * @param tp the thread pool handle.
221 * @param job_fn Function to run. Must not be NULL.
222 * @param user_data User data provided to thread_fn.
223 * @return OPJ_TRUE if the job was successfully submitted.
224 */
225 OPJ_BOOL opj_thread_pool_submit_job(opj_thread_pool_t* tp, opj_job_fn job_fn,
226 void* user_data);
227
228 /** Wait that no more than max_remaining_jobs jobs are remaining in the queue of
229 * the thread pool. The aim of this function is to avoid submitting too many
230 * jobs while the thread pool cannot cope fast enough with them, which would
231 * result potentially in out-of-memory situations with too many job descriptions
232 * being queued.
233 *
234 * @param tp the thread pool handle
235 * @param max_remaining_jobs maximum number of jobs allowed to be queued without waiting.
236 */
237 void opj_thread_pool_wait_completion(opj_thread_pool_t* tp,
238 int max_remaining_jobs);
239
240 /** Return the number of threads associated with the thread pool.
241 *
242 * @param tp the thread pool handle.
243 * @return number of threads associated with the thread pool.
244 */
245 int opj_thread_pool_get_thread_count(opj_thread_pool_t* tp);
246
247 /** Destroy a thread pool.
248 * @param tp the thread pool handle.
249 */
250 void opj_thread_pool_destroy(opj_thread_pool_t* tp);
251
252 /*@}*/
253
254 /*@}*/
255
256 #endif /* THREAD_H */