ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Coro/Changes
(Generate patch)

Comparing Coro/Changes (file contents):
Revision 1.625 by root, Tue Mar 4 05:07:44 2014 UTC vs.
Revision 1.659 by root, Wed Jun 22 22:53:49 2016 UTC

1Revision history for Perl extension Coro. 1Revision history for Perl extension Coro.
2 2
3TODO: should explore PerlIO::coroaio (perl leaks like hell). 3TODO: should explore PerlIO::coroaio (perl leaks like hell).
4TODO: channel->maxsize(newsize)? 4TODO: channel->maxsize(newsize)?
5TODO: __GCC_HAVE_DWARF2_CFI_ASM 5TODO: __GCC_HAVE_DWARF2_CFI_ASM
6TODO: swap_sv, maybe add scope_swap_sv, andallow to unswap by repeat? 6TODO: swap_sv, maybe add scope_swap_sv?
7TODO: swap_sv not undone in pool 7TODO: croak when async_pool tries to run canceled thread?
8 8
9Program terminated with signal 11, Segmentation fault. 9 - since various broken or deficient patches float around
10#0 coro_semaphore_adjust (av=0x0, adjust=0) at State.xs:2915 10 to work around the vtbl API breakage in perl, let's provide
112915 State.xs: No such file or directory. 11 out own workaround, which seems to be much less invasive
12(gdb) bt 12 and more compatible than the approaches seen so far. YMMV.
13#0 coro_semaphore_adjust (av=0x0, adjust=0) at State.xs:2915 13 - work around assertion failure in perl_destruct on 5.24
14#1 0x00007f638f0c0703 in slf_destroy (coro=0x5957180) at State.xs:2605 14 (analyzed by Dave Mitchell).
15#2 coro_state_destroy (coro=0x5957180) at State.xs:1712
16#3 0x00007f638f0c150c in coro_state_destroy (coro=<optimized out>) at State.xs:1709
17#4 XS_Coro__destroy (cv=<optimized out>) at State.xs:3853
18#5 0x00000000004b572d in Perl_pp_entersub () at pp_hot.c:2881
19#6 0x00000000004adfe3 in Perl_runops_standard () at run.c:42
20#7 0x000000000044335f in S_run_body (oldscope=<optimized out>) at perl.c:2462
21#8 perl_run (my_perl=<optimized out>) at perl.c:2383
22#9 0x00007f638f0ba3a1 in cctx_run (arg=<optimized out>) at State.xs:1478
23#10 0x00007f638f0b74d5 in coro_init () at libcoro/coro.c:96
24(gdb) up
25#1 0x00007f638f0c0703 in slf_destroy (coro=0x5957180) at State.xs:2605
262605 in State.xs
27(gdb) p coro->slf_frame
28$1 = {
29 prepare = 0x7f638f0baf60 <prepare_schedule>,
30 check = 0x7f638f0b6e70 <slf_check_repeat>,
31 data = 0x0,
32 destroy = 0x7f638f0bb820 <coro_semaphore_destroy>
33 15
166.5 Wed Jun 22 22:23:50 CEST 2016
17 - swap_sv swapping order was not symmetrical, causing
18 wrong swaps when swap_sv was used multiple times on the
19 same sv in the same thread.
20 - swap_sv calls can now be undone by calling it again
21 with the same variables.
22 - swap_sv calls will now be undone in async_pool threads.
23 - split Coro::Semaphore::up/adjust into separate xs functions
24 for better error reporting, at slight codesize increase.
25 - (libcoro) arm assembly support, please test and report.
26 - adjust to PL_savestack changes in perl 5.24 (adapted from
27 the debian patch, which unfortunately gets it wrong).
34 28
35TODO: warnhook reports from wrong line number now, when arg is Math::GMP number. 296.49 Sat Oct 17 01:40:12 CEST 2015
30 - throwing an exception to a thread waiting in
31 Coro::Handle using Coro::EV did not stop the watchers,
32 causing the next call to fail (testcase by Martin Pritchard).
33 - bump minimum perl version to 5.10.
34
356.48 Sun Oct 4 19:03:51 CEST 2015
36 - fix memory leak when Coro::Handle uses Coro::EV internally
37 (testcase by Sten Sten).
38 - update code to libev 4 API (internally, Coro still used the
39 version 3 API calls).
40 - remove unused hv_sig.
41
426.47 Sat Jul 11 03:58:20 CEST 2015
43 - swap_svs - NVs can be in the SV head beginning with 5.20.
44
456.46 Tue Jun 30 14:36:30 CEST 2015
46 - restore portability to perls with windows fork emulation
47 (patch by Petr Písař).
48
496.45 Tue Jun 30 01:40:08 CEST 2015
50 - restore portability to perl 5.16 and below.
51
526.44 Tue Jun 30 00:41:54 CEST 2015
53 - avoid segfaulting (or worse) when tracing a canceled thread.
54 - the Event module silently broke it's public hook API, causing
55 failures on perls compiled with -Duselongdouble. Requiring
56 the latest version of Event because I don't know which release
57 changed this (it's not mentioned in the ChangeLog).
58 - allow xs level enterleave hooks via CoroAPI.
59
606.43 Thu Jun 4 15:38:14 CEST 2015
61 - use stability canary.
62 - port to stableperl-5.22.0-1.001.
63 - update libecb.
64
656.42 Wed Feb 11 20:29:52 CET 2015
66 - Coro::SemaphoreSet->try did not actually work (analyzed by
67 SATO Kentaro).
68 - upgrade libecb to be C11 compliant.
69
706.41 Sat Sep 6 22:08:46 CEST 2014
71 - restore portability to perl 5.8.x.
72 - give new Coro's a valid GvHV(PL_hintgv) - this is slow and takes
73 up some memory, but fixes "use feature" and similar modules
74 when used inside a Coro.
75 - allow zero as argument to Coro::Channel to mean the same thing
76 as no argument. this works with older versions as well,
77 but wasn't legal until now.
78 - slightly better c header file detection.
79
806.39 Mon Jun 2 00:00:08 CEST 2014
81 - work around more incompatible changes in 5.20.
82
836.38 Sun Jun 1 21:54:23 CEST 2014
84 - check that perl slots actually have enough space to hold
85 interpreter variables.
86 - untested port to perl 5.19 (64 bit tmps indices) (reported
87 by Andreas König).
88 - croak when cancel is called without a thread context.
89
906.37 Tue Mar 4 13:27:33 CET 2014
91 - *sigh*, removed leftover debugging code from debugging a
92 perl bug, of all things.
93
946.36 Tue Mar 4 07:11:59 CET 2014
95 - semaphores would not clear the destroy hook when interrupted
96 by ->throw, causing segfaults or worse.
97 - ->throw on a thread waiting for a semaphore did not acquire
98 the semaphore, but also didn't wake up other waiters,
99 possibly causing a deadlock.
36 - FATAL: $Coro::IDLE blocked itself will now use Carp::confess 100 - "FATAL: $Coro::IDLE blocked itself" will now use Carp::confess
37 to report a full stacktrace, which should help find out 101 to report a full stacktrace, which should help find out
38 where the actual call is. 102 where the actual call is.
39 - "atomically" destroy data in slf_destroy, because it is 103 - "atomically" destroy data in slf_destroy, because it is
40 the right thing to do, just in case. 104 the right thing to do, just in case.
41 - disable ecb.h libm dependency, to compile on ancient systems 105 - disable ecb.h libm dependency, to compile on ancient systems
147 handle and barfed. now it's just a bit slower on gentoo and similar 211 handle and barfed. now it's just a bit slower on gentoo and similar
148 systems. 212 systems.
149 213
1506.01 Sun Jul 3 12:31:14 CEST 2011 2146.01 Sun Jul 3 12:31:14 CEST 2011
151 - workarounds are good, but the test for whether pthreads are used 215 - workarounds are good, but the test for whether pthreads are used
152 was not good. thisone should be better. 216 was not good. this one should be better.
153 - check differently whether gcc generates cfi instructions itself. 217 - check differently whether gcc generates cfi instructions itself.
154 218
1556.0 Wed Jun 29 19:43:35 CEST 2011 2196.0 Wed Jun 29 19:43:35 CEST 2011
156 - INCOMPATIBLE CHANGE: unreferenced coro objects will now be 220 - INCOMPATIBLE CHANGE: unreferenced coro objects will now be
157 destroyed and cleaned up automatically (e.g. async { schedule }). 221 destroyed and cleaned up automatically (e.g. async { schedule }).
158 - implement a JIT compiler for part of the thread switch code, 222 - implement a JIT compiler for part of the thread switch code,
159 which gives a 50% speed improvement on threaded perls, and 223 which gives a 50% speed improvement on threaded perls, and
160 about 4% on non-thraeded perls (so threaded perls now finally 224 about 4% on non-threaded perls (so threaded perls now finally
161 reach about half the speed of non-threaded perls). 225 reach about half the speed of non-threaded perls).
162 - slightly modernise Coro::Intro, add section about rouse functions. 226 - slightly modernise Coro::Intro, add section about rouse functions.
163 - avoid DEFSV and ERRSV, giving another 10% improvement 227 - avoid DEFSV and ERRSV, giving another 10% improvement
164 in thread switching. 228 in thread switching.
165 - Coro::State->is_destroyed is now called is_zombie. 229 - Coro::State->is_destroyed is now called is_zombie.

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines