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.662 by root, Sun Jun 26 21:46:03 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. 96.511 Sun Jun 26 23:44:50 CEST 2016
10#0 coro_semaphore_adjust (av=0x0, adjust=0) at State.xs:2915 10 - make it compile with threaded perls again.
112915 State.xs: No such file or directory. 11 - simplify and speed up __DIE__ and __WARN__ handling.
12(gdb) bt
13#0 coro_semaphore_adjust (av=0x0, adjust=0) at State.xs:2915
14#1 0x00007f638f0c0703 in slf_destroy (coro=0x5957180) at State.xs:2605
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 12
136.51 Sat Jun 25 20:57:20 CEST 2016
14 - 6.5 release didn't compile on most older perls due to
15 a logic error enabling experimental 5.24 code for all versions.
16 - since various broken or deficient patches float around
17 to work around the vtbl API breakage in perl, let's provide
18 our own workaround, which seems to be much less invasive
19 and more compatible than the approaches seen so far. YMMV.
20 - work around assertion failure in perl_destruct on 5.24
21 (analyzed by Dave Mitchell).
34 22
35TODO: warnhook reports from wrong line number now, when arg is Math::GMP number. 236.5 Wed Jun 22 22:23:50 CEST 2016
24 - swap_sv swapping order was not symmetrical, causing
25 wrong swaps when swap_sv was used multiple times on the
26 same sv in the same thread.
27 - swap_sv calls can now be undone by calling it again
28 with the same variables.
29 - swap_sv calls will now be undone in async_pool threads.
30 - split Coro::Semaphore::up/adjust into separate xs functions
31 for better error reporting, at slight codesize increase.
32 - (libcoro) arm assembly support, please test and report.
33 - adjust to PL_savestack changes in perl 5.24 (adapted from
34 the debian patch, which unfortunately gets it wrong).
35
366.49 Sat Oct 17 01:40:12 CEST 2015
37 - throwing an exception to a thread waiting in
38 Coro::Handle using Coro::EV did not stop the watchers,
39 causing the next call to fail (testcase by Martin Pritchard).
40 - bump minimum perl version to 5.10.
41
426.48 Sun Oct 4 19:03:51 CEST 2015
43 - fix memory leak when Coro::Handle uses Coro::EV internally
44 (testcase by Sten Sten).
45 - update code to libev 4 API (internally, Coro still used the
46 version 3 API calls).
47 - remove unused hv_sig.
48
496.47 Sat Jul 11 03:58:20 CEST 2015
50 - swap_svs - NVs can be in the SV head beginning with 5.20.
51
526.46 Tue Jun 30 14:36:30 CEST 2015
53 - restore portability to perls with windows fork emulation
54 (patch by Petr Písař).
55
566.45 Tue Jun 30 01:40:08 CEST 2015
57 - restore portability to perl 5.16 and below.
58
596.44 Tue Jun 30 00:41:54 CEST 2015
60 - avoid segfaulting (or worse) when tracing a canceled thread.
61 - the Event module silently broke it's public hook API, causing
62 failures on perls compiled with -Duselongdouble. Requiring
63 the latest version of Event because I don't know which release
64 changed this (it's not mentioned in the ChangeLog).
65 - allow xs level enterleave hooks via CoroAPI.
66
676.43 Thu Jun 4 15:38:14 CEST 2015
68 - use stability canary.
69 - port to stableperl-5.22.0-1.001.
70 - update libecb.
71
726.42 Wed Feb 11 20:29:52 CET 2015
73 - Coro::SemaphoreSet->try did not actually work (analyzed by
74 SATO Kentaro).
75 - upgrade libecb to be C11 compliant.
76
776.41 Sat Sep 6 22:08:46 CEST 2014
78 - restore portability to perl 5.8.x.
79 - give new Coro's a valid GvHV(PL_hintgv) - this is slow and takes
80 up some memory, but fixes "use feature" and similar modules
81 when used inside a Coro.
82 - allow zero as argument to Coro::Channel to mean the same thing
83 as no argument. this works with older versions as well,
84 but wasn't legal until now.
85 - slightly better c header file detection.
86
876.39 Mon Jun 2 00:00:08 CEST 2014
88 - work around more incompatible changes in 5.20.
89
906.38 Sun Jun 1 21:54:23 CEST 2014
91 - check that perl slots actually have enough space to hold
92 interpreter variables.
93 - untested port to perl 5.19 (64 bit tmps indices) (reported
94 by Andreas König).
95 - croak when cancel is called without a thread context.
96
976.37 Tue Mar 4 13:27:33 CET 2014
98 - *sigh*, removed leftover debugging code from debugging a
99 perl bug, of all things.
100
1016.36 Tue Mar 4 07:11:59 CET 2014
102 - semaphores would not clear the destroy hook when interrupted
103 by ->throw, causing segfaults or worse.
104 - ->throw on a thread waiting for a semaphore did not acquire
105 the semaphore, but also didn't wake up other waiters,
106 possibly causing a deadlock.
36 - FATAL: $Coro::IDLE blocked itself will now use Carp::confess 107 - "FATAL: $Coro::IDLE blocked itself" will now use Carp::confess
37 to report a full stacktrace, which should help find out 108 to report a full stacktrace, which should help find out
38 where the actual call is. 109 where the actual call is.
39 - "atomically" destroy data in slf_destroy, because it is 110 - "atomically" destroy data in slf_destroy, because it is
40 the right thing to do, just in case. 111 the right thing to do, just in case.
41 - disable ecb.h libm dependency, to compile on ancient systems 112 - 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 218 handle and barfed. now it's just a bit slower on gentoo and similar
148 systems. 219 systems.
149 220
1506.01 Sun Jul 3 12:31:14 CEST 2011 2216.01 Sun Jul 3 12:31:14 CEST 2011
151 - workarounds are good, but the test for whether pthreads are used 222 - workarounds are good, but the test for whether pthreads are used
152 was not good. thisone should be better. 223 was not good. this one should be better.
153 - check differently whether gcc generates cfi instructions itself. 224 - check differently whether gcc generates cfi instructions itself.
154 225
1556.0 Wed Jun 29 19:43:35 CEST 2011 2266.0 Wed Jun 29 19:43:35 CEST 2011
156 - INCOMPATIBLE CHANGE: unreferenced coro objects will now be 227 - INCOMPATIBLE CHANGE: unreferenced coro objects will now be
157 destroyed and cleaned up automatically (e.g. async { schedule }). 228 destroyed and cleaned up automatically (e.g. async { schedule }).
158 - implement a JIT compiler for part of the thread switch code, 229 - implement a JIT compiler for part of the thread switch code,
159 which gives a 50% speed improvement on threaded perls, and 230 which gives a 50% speed improvement on threaded perls, and
160 about 4% on non-thraeded perls (so threaded perls now finally 231 about 4% on non-threaded perls (so threaded perls now finally
161 reach about half the speed of non-threaded perls). 232 reach about half the speed of non-threaded perls).
162 - slightly modernise Coro::Intro, add section about rouse functions. 233 - slightly modernise Coro::Intro, add section about rouse functions.
163 - avoid DEFSV and ERRSV, giving another 10% improvement 234 - avoid DEFSV and ERRSV, giving another 10% improvement
164 in thread switching. 235 in thread switching.
165 - Coro::State->is_destroyed is now called is_zombie. 236 - Coro::State->is_destroyed is now called is_zombie.

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines