… | |
… | |
27 | |
27 | |
28 | #ifndef SvREFCNT_dec_NN |
28 | #ifndef SvREFCNT_dec_NN |
29 | #define SvREFCNT_dec_NN(sv) SvREFCNT_dec (sv) |
29 | #define SvREFCNT_dec_NN(sv) SvREFCNT_dec (sv) |
30 | #endif |
30 | #endif |
31 | |
31 | |
|
|
32 | #ifndef SvREFCNT_dec_simple_void_NN |
|
|
33 | #define SvREFCNT_dec_simple_void_NN(sv) SvREFCNT_dec (sv) |
|
|
34 | #endif |
|
|
35 | |
32 | #ifndef SvREFCNT_inc_NN |
36 | #ifndef SvREFCNT_inc_NN |
33 | #define SvREFCNT_inc_NN(sv) SvREFCNT_inc (sv) |
37 | #define SvREFCNT_inc_NN(sv) SvREFCNT_inc (sv) |
34 | #endif |
38 | #endif |
35 | |
39 | |
|
|
40 | #ifndef RECURSION_CHECK |
36 | #define RECURSION_CHECK 0 |
41 | #define RECURSION_CHECK 0 |
|
|
42 | #endif |
37 | |
43 | |
38 | static X_TLS_DECLARE(current_key); |
44 | static X_TLS_DECLARE(current_key); |
39 | #if RECURSION_CHECK |
45 | #if RECURSION_CHECK |
40 | static X_TLS_DECLARE(check_key); |
46 | static X_TLS_DECLARE(check_key); |
41 | #endif |
47 | #endif |
42 | |
48 | |
|
|
49 | static void |
|
|
50 | fatal (const char *msg) |
|
|
51 | { |
|
|
52 | write (2, msg, strlen (msg)); |
|
|
53 | abort (); |
|
|
54 | } |
43 | |
55 | |
44 | static s_epipe ep; |
56 | static s_epipe ep; |
45 | static void *perl_thx; |
57 | static void *perl_thx; |
46 | static sigset_t cursigset, fullsigset; |
58 | static sigset_t cursigset, fullsigset; |
47 | |
59 | |
… | |
… | |
188 | } |
200 | } |
189 | |
201 | |
190 | static void |
202 | static void |
191 | pmapi_release (void) |
203 | pmapi_release (void) |
192 | { |
204 | { |
|
|
205 | if (! ((thread_enable ? thread_enable : global_enable) & 1)) |
|
|
206 | { |
|
|
207 | X_TLS_SET (current_key, 0); |
|
|
208 | return; |
|
|
209 | } |
|
|
210 | |
193 | #if RECURSION_CHECK |
211 | #if RECURSION_CHECK |
194 | if (X_TLS_GET (check_key)) |
212 | if (X_TLS_GET (check_key)) |
195 | croak ("perlinterp_release () called without valid perl context"); |
213 | fatal ("FATAL: perlinterp_release () called without valid perl context"); |
196 | |
214 | |
197 | X_TLS_SET (check_key, &check_key); |
215 | X_TLS_SET (check_key, &check_key); |
198 | #endif |
216 | #endif |
199 | |
|
|
200 | if (! ((thread_enable ? thread_enable : global_enable) & 1)) |
|
|
201 | { |
|
|
202 | X_TLS_SET (current_key, 0); |
|
|
203 | return; |
|
|
204 | } |
|
|
205 | |
217 | |
206 | struct tctx *ctx = tctx_get (); |
218 | struct tctx *ctx = tctx_get (); |
207 | ctx->coro = SvREFCNT_inc_simple_NN (CORO_CURRENT); |
219 | ctx->coro = SvREFCNT_inc_simple_NN (CORO_CURRENT); |
208 | ctx->wait_f = 0; |
220 | ctx->wait_f = 0; |
209 | |
221 | |
… | |
… | |
231 | pmapi_acquire (void) |
243 | pmapi_acquire (void) |
232 | { |
244 | { |
233 | int jeret; |
245 | int jeret; |
234 | struct tctx *ctx = X_TLS_GET (current_key); |
246 | struct tctx *ctx = X_TLS_GET (current_key); |
235 | |
247 | |
|
|
248 | if (!ctx) |
|
|
249 | return; |
|
|
250 | |
236 | #if RECURSION_CHECK |
251 | #if RECURSION_CHECK |
237 | if (X_TLS_GET (check_key) != &check_key) |
252 | if (X_TLS_GET (check_key) != &check_key) |
238 | croak ("perlinterp_acquire () called with valid perl context"); |
253 | fatal ("FATAL: perlinterp_acquire () called with valid perl context"); |
239 | |
254 | |
240 | X_TLS_SET (check_key, 0); |
255 | X_TLS_SET (check_key, 0); |
241 | #endif |
256 | #endif |
242 | |
|
|
243 | if (!ctx) |
|
|
244 | return; |
|
|
245 | |
257 | |
246 | X_LOCK (acquire_m); |
258 | X_LOCK (acquire_m); |
247 | |
259 | |
248 | tctxs_put (&acquirers, ctx); |
260 | tctxs_put (&acquirers, ctx); |
249 | |
261 | |
… | |
… | |
289 | |
301 | |
290 | perl_thx = PERL_GET_CONTEXT; |
302 | perl_thx = PERL_GET_CONTEXT; |
291 | |
303 | |
292 | I_CORO_API ("Coro::Multicore"); |
304 | I_CORO_API ("Coro::Multicore"); |
293 | |
305 | |
|
|
306 | if (0) { /*D*/ |
294 | X_LOCK (release_m); |
307 | X_LOCK (release_m); |
295 | while (idle < min_idle) |
308 | while (idle < min_idle) |
296 | start_thread (); |
309 | start_thread (); |
297 | X_UNLOCK (release_m); |
310 | X_UNLOCK (release_m); |
|
|
311 | } |
298 | |
312 | |
299 | /* not perfectly efficient to do it this way, but it is simple */ |
313 | /* not perfectly efficient to do it this way, but it is simple */ |
300 | perl_multicore_init (); /* calls release */ |
314 | perl_multicore_init (); /* calls release */ |
301 | perl_multicore_api->pmapi_release = pmapi_release; |
315 | perl_multicore_api->pmapi_release = pmapi_release; |
302 | perl_multicore_api->pmapi_acquire = pmapi_acquire; |
316 | perl_multicore_api->pmapi_acquire = pmapi_acquire; |
… | |
… | |
322 | scoped_disable () |
336 | scoped_disable () |
323 | CODE: |
337 | CODE: |
324 | LEAVE; /* see Guard.xs */ |
338 | LEAVE; /* see Guard.xs */ |
325 | CORO_ENTERLEAVE_SCOPE_HOOK (set_thread_enable, (void *)2, set_thread_enable, (void *)0); |
339 | CORO_ENTERLEAVE_SCOPE_HOOK (set_thread_enable, (void *)2, set_thread_enable, (void *)0); |
326 | ENTER; /* see Guard.xs */ |
340 | ENTER; /* see Guard.xs */ |
|
|
341 | |
|
|
342 | #if 0 |
327 | |
343 | |
328 | U32 |
344 | U32 |
329 | min_idle_threads (U32 min = NO_INIT) |
345 | min_idle_threads (U32 min = NO_INIT) |
330 | CODE: |
346 | CODE: |
331 | X_LOCK (acquire_m); |
347 | X_LOCK (acquire_m); |
… | |
… | |
333 | if (items) |
349 | if (items) |
334 | min_idle = min; |
350 | min_idle = min; |
335 | X_UNLOCK (acquire_m); |
351 | X_UNLOCK (acquire_m); |
336 | OUTPUT: |
352 | OUTPUT: |
337 | RETVAL |
353 | RETVAL |
338 | |
354 | |
|
|
355 | #endif |
339 | |
356 | |
340 | int |
357 | int |
341 | fd () |
358 | fd () |
342 | CODE: |
359 | CODE: |
343 | RETVAL = s_epipe_fd (&ep); |
360 | RETVAL = s_epipe_fd (&ep); |
… | |
… | |
351 | X_LOCK (acquire_m); |
368 | X_LOCK (acquire_m); |
352 | while (acquirers.cur) |
369 | while (acquirers.cur) |
353 | { |
370 | { |
354 | struct tctx *ctx = tctxs_get (&acquirers); |
371 | struct tctx *ctx = tctxs_get (&acquirers); |
355 | CORO_READY ((SV *)ctx->coro); |
372 | CORO_READY ((SV *)ctx->coro); |
356 | SvREFCNT_dec_NN ((SV *)ctx->coro); |
373 | SvREFCNT_dec_simple_void_NN ((SV *)ctx->coro); |
357 | ctx->coro = 0; |
374 | ctx->coro = 0; |
358 | } |
375 | } |
359 | X_UNLOCK (acquire_m); |
376 | X_UNLOCK (acquire_m); |
360 | |
377 | |
361 | void |
378 | void |