1 | Revision history for Perl extension Coro. |
1 | Revision history for Perl extension Coro. |
2 | |
2 | |
3 | TODO: should explore PerlIO::coroaio (perl leaks like hell). |
3 | TODO: should explore PerlIO::coroaio (perl leaks like hell). |
4 | TODO: channel->maxsize(newsize)? |
4 | TODO: channel->maxsize(newsize)? |
5 | TODO: __GCC_HAVE_DWARF2_CFI_ASM |
5 | TODO: __GCC_HAVE_DWARF2_CFI_ASM |
|
|
6 | TODO: swap_sv, maybe add scope_swap_sv? |
|
|
7 | TODO: croak when async_pool tries to run canceled thread? |
|
|
8 | TODO: how to debug safe_cancel failure (vebrose mode? show how to make backtrace?) |
|
|
9 | TODO: scalar context for Coro::AIO wrappers? |
6 | |
10 | |
|
|
11 | TODO: State.xs could short-circuit some macros such as CORO_EXECUTE_SLF |
|
|
12 | TODO: use frame->destroy to improve Coro::EV |
|
|
13 | |
|
|
14 | 6.56 Thu Feb 20 19:40:07 CET 2020 |
|
|
15 | - Coro::EV::time*once functions used ev_once, which is not cancelable. |
|
|
16 | This could cause problems due to I/O watchers not being stopped up |
|
|
17 | on exceptions/cancellation. |
|
|
18 | |
|
|
19 | 6.55 Fri Jul 19 17:28:09 CEST 2019 |
|
|
20 | - Coro::RWLock woke up only one reader instead of all after a wrlock |
|
|
21 | (analyzed and patch by Maxim Skorobogatov). |
|
|
22 | - slightly improved documentation of Coro::RWLock and RWLock testcase. |
|
|
23 | - quickly (re)-ported to minix 3.3 before minix crashed again. |
|
|
24 | |
|
|
25 | 6.54 Sun Dec 16 11:06:07 CET 2018 |
|
|
26 | - reinstate Coro::Select::select prototype - it breaks more than it fixes. |
|
|
27 | |
|
|
28 | 6.53 Sun Dec 16 10:33:15 CET 2018 |
|
|
29 | - the autogenerated prototypes of Coro::AIO now add ";" at the end |
|
|
30 | to avoid generating named unary operators and messing up parsing |
|
|
31 | (mostly affects aio_mlockall 4 | 8 which was parsed as |
|
|
32 | (aio_mlockall 4) | 8). |
|
|
33 | - do not use a prototype for select in Coro::Select, as CORE::select also |
|
|
34 | doesn't have one. |
|
|
35 | |
|
|
36 | 6.52 Tue Aug 14 18:49:43 CEST 2018 |
|
|
37 | - libcoro update: allow sharing of coro threads using the pthreads |
|
|
38 | backend among different pthreads, as is required by Coro::Multicore. |
|
|
39 | - always allow ->call and ->eval when the coro is the current coroutine. this |
|
|
40 | makes it possible, among other things, to call these on $Coro::main. |
|
|
41 | - minor code cleanups. |
|
|
42 | |
|
|
43 | 6.514 Thu Aug 31 18:25:31 CEST 2017 |
|
|
44 | - safe_cancel no longer croaks when called on already-destroyed |
|
|
45 | thread, but instead "just works". |
|
|
46 | |
|
|
47 | 6.513 Sat Jul 15 01:18:51 CEST 2017 |
|
|
48 | - experimental 5.22 comaptibility changes (PadlistNAMES). |
|
|
49 | - removed attributes example and made sure the other examples |
|
|
50 | still work. |
|
|
51 | - fix some statevar types for newer perls, should be of no consequence. |
|
|
52 | |
|
|
53 | 6.512 Fri Jul 14 05:03:17 CEST 2017 |
|
|
54 | - seems to pass test suite down till 5.8.9, so make this the |
|
|
55 | minimum requirement in Makefile.PL. |
|
|
56 | - experimental 5.24 compatibility changes (SUB_ARGARRAY). |
|
|
57 | - experimental 5.26 compatibility changes (PL_comppad -> PADOFFSET). |
|
|
58 | - disable FORTIFY_SOURCE to avoid broken (but well-intentioned) |
|
|
59 | fortified longjmp variants in some libcs. |
|
|
60 | - re-try JIT allocation without PROT_EXEC, to hopefully improve |
|
|
61 | portability (still doesn't seem to work around broken selinux |
|
|
62 | mmap everywhere). |
|
|
63 | - speling fixes (Xavier Guimard). |
|
|
64 | |
|
|
65 | 6.511 Sun Jun 26 23:44:50 CEST 2016 |
|
|
66 | - make it compile with threaded perls again. |
|
|
67 | - simplify and speed up __DIE__ and __WARN__ handling. |
|
|
68 | |
|
|
69 | 6.51 Sat Jun 25 20:57:20 CEST 2016 |
|
|
70 | - 6.5 release didn't compile on most older perls due to |
|
|
71 | a logic error enabling experimental 5.24 code for all versions. |
|
|
72 | - since various broken or deficient patches float around |
|
|
73 | to work around the vtbl API breakage in perl, let's provide |
|
|
74 | our own workaround, which seems to be much less invasive |
|
|
75 | and more compatible than the approaches seen so far. YMMV. |
|
|
76 | - work around assertion failure in perl_destruct on 5.24 |
|
|
77 | (analyzed by Dave Mitchell). |
|
|
78 | |
|
|
79 | 6.5 Wed Jun 22 22:23:50 CEST 2016 |
|
|
80 | - swap_sv swapping order was not symmetrical, causing |
|
|
81 | wrong swaps when swap_sv was used multiple times on the |
|
|
82 | same sv in the same thread. |
|
|
83 | - swap_sv calls can now be undone by calling it again |
|
|
84 | with the same variables. |
|
|
85 | - swap_sv calls will now be undone in async_pool threads. |
|
|
86 | - split Coro::Semaphore::up/adjust into separate xs functions |
|
|
87 | for better error reporting, at slight codesize increase. |
|
|
88 | - (libcoro) arm assembly support, please test and report. |
|
|
89 | - adjust to PL_savestack changes in perl 5.24 (adapted from |
|
|
90 | the debian patch, which unfortunately gets it wrong). |
|
|
91 | |
|
|
92 | 6.49 Sat Oct 17 01:40:12 CEST 2015 |
|
|
93 | - throwing an exception to a thread waiting in |
|
|
94 | Coro::Handle using Coro::EV did not stop the watchers, |
|
|
95 | causing the next call to fail (testcase by Martin Pritchard). |
|
|
96 | - bump minimum perl version to 5.10. |
|
|
97 | |
|
|
98 | 6.48 Sun Oct 4 19:03:51 CEST 2015 |
|
|
99 | - fix memory leak when Coro::Handle uses Coro::EV internally |
|
|
100 | (testcase by Sten Sten). |
|
|
101 | - update code to libev 4 API (internally, Coro still used the |
|
|
102 | version 3 API calls). |
|
|
103 | - remove unused hv_sig. |
|
|
104 | |
|
|
105 | 6.47 Sat Jul 11 03:58:20 CEST 2015 |
|
|
106 | - swap_svs - NVs can be in the SV head beginning with 5.20. |
|
|
107 | |
|
|
108 | 6.46 Tue Jun 30 14:36:30 CEST 2015 |
|
|
109 | - restore portability to perls with windows fork emulation |
|
|
110 | (patch by Petr Písař). |
|
|
111 | |
|
|
112 | 6.45 Tue Jun 30 01:40:08 CEST 2015 |
|
|
113 | - restore portability to perl 5.16 and below. |
|
|
114 | |
|
|
115 | 6.44 Tue Jun 30 00:41:54 CEST 2015 |
|
|
116 | - avoid segfaulting (or worse) when tracing a canceled thread. |
|
|
117 | - the Event module silently broke it's public hook API, causing |
|
|
118 | failures on perls compiled with -Duselongdouble. Requiring |
|
|
119 | the latest version of Event because I don't know which release |
|
|
120 | changed this (it's not mentioned in the ChangeLog). |
|
|
121 | - allow xs level enterleave hooks via CoroAPI. |
|
|
122 | |
|
|
123 | 6.43 Thu Jun 4 15:38:14 CEST 2015 |
|
|
124 | - use stability canary. |
|
|
125 | - port to stableperl-5.22.0-1.001. |
|
|
126 | - update libecb. |
|
|
127 | |
|
|
128 | 6.42 Wed Feb 11 20:29:52 CET 2015 |
|
|
129 | - Coro::SemaphoreSet->try did not actually work (analyzed by |
|
|
130 | SATO Kentaro). |
|
|
131 | - upgrade libecb to be C11 compliant. |
|
|
132 | |
|
|
133 | 6.41 Sat Sep 6 22:08:46 CEST 2014 |
|
|
134 | - restore portability to perl 5.8.x. |
|
|
135 | - give new Coro's a valid GvHV(PL_hintgv) - this is slow and takes |
|
|
136 | up some memory, but fixes "use feature" and similar modules |
|
|
137 | when used inside a Coro. |
|
|
138 | - allow zero as argument to Coro::Channel to mean the same thing |
|
|
139 | as no argument. this works with older versions as well, |
|
|
140 | but wasn't legal until now. |
|
|
141 | - slightly better c header file detection. |
|
|
142 | |
|
|
143 | 6.39 Mon Jun 2 00:00:08 CEST 2014 |
|
|
144 | - work around more incompatible changes in 5.20. |
|
|
145 | |
|
|
146 | 6.38 Sun Jun 1 21:54:23 CEST 2014 |
|
|
147 | - check that perl slots actually have enough space to hold |
|
|
148 | interpreter variables. |
|
|
149 | - untested port to perl 5.19 (64 bit tmps indices) (reported |
|
|
150 | by Andreas König). |
|
|
151 | - croak when cancel is called without a thread context. |
|
|
152 | |
|
|
153 | 6.37 Tue Mar 4 13:27:33 CET 2014 |
|
|
154 | - *sigh*, removed leftover debugging code from debugging a |
|
|
155 | perl bug, of all things. |
|
|
156 | |
|
|
157 | 6.36 Tue Mar 4 07:11:59 CET 2014 |
|
|
158 | - semaphores would not clear the destroy hook when interrupted |
|
|
159 | by ->throw, causing segfaults or worse. |
|
|
160 | - ->throw on a thread waiting for a semaphore did not acquire |
|
|
161 | the semaphore, but also didn't wake up other waiters, |
|
|
162 | possibly causing a deadlock. |
|
|
163 | - "FATAL: $Coro::IDLE blocked itself" will now use Carp::confess |
|
|
164 | to report a full stacktrace, which should help find out |
|
|
165 | where the actual call is. |
|
|
166 | - "atomically" destroy data in slf_destroy, because it is |
|
|
167 | the right thing to do, just in case. |
|
|
168 | - disable ecb.h libm dependency, to compile on ancient systems |
|
|
169 | or under adverse conditions. |
|
|
170 | |
|
|
171 | 6.33 Mon Nov 18 11:26:27 CET 2013 |
|
|
172 | - do not crash when freeing padlists with holes (in 5.18). |
|
|
173 | - tentative SVt_BIND 5.19 port/fix. |
|
|
174 | |
|
|
175 | 6.32 Tue Nov 5 15:35:35 CET 2013 |
|
|
176 | - use a new algorithm to derive padlists for perl 5.18. The old |
|
|
177 | one could lead to 0-pointer accesses inside perl (reported |
|
|
178 | by Darin McBride). |
|
|
179 | |
|
|
180 | 6.31 Thu May 9 07:39:48 CEST 2013 |
|
|
181 | - Coro::AIO requests would crash if the thread was ready'd |
|
|
182 | while the request was ongoing. |
|
|
183 | |
|
|
184 | 6.29 Wed May 8 02:55:18 CEST 2013 |
|
|
185 | - when an on_destroy handler destructs the coro currently being |
|
|
186 | destructed a perl scalar could be accessed after being freed, |
|
|
187 | likely causing a crash. |
|
|
188 | |
|
|
189 | 6.28 Wed Mar 6 06:58:02 CET 2013 |
|
|
190 | - clean remnants of existing __DIE__ and __WARN__ handlers so |
|
|
191 | they lose their magic and will not cause segfaults later |
|
|
192 | (testcase by Andrey Sagulin). |
7 | - improved Coro::State documentation a bit. |
193 | - improved Coro::State documentation a bit. |
8 | - Coro::Debug::command now flushes the output. |
194 | - Coro::Debug::command now flushes the output. |
9 | - add hack detection code for x32 abi, because the braindead slugs |
195 | - add hack detection code for x32 abi, because the braindead slugs |
10 | who designed that made it look exactly like x86_64 without |
196 | who designed that made it look exactly like x86_64 without |
11 | providing proper compile time symbols to test for it. as a result, |
197 | providing proper compile time symbols to test for it. as a result, |
12 | this detection cannot work reliably. |
198 | this detection cannot work reliably. |
|
|
199 | - valgrind stack registering was broken. |
|
|
200 | - do not rely on Time::HiRes anymore in Coro::Debug. |
13 | |
201 | |
14 | 6.23 Fri Dec 7 23:36:37 CET 2012 |
202 | 6.23 Fri Dec 7 23:36:37 CET 2012 |
15 | - use experimental fiber implementation on native windows |
203 | - use experimental fiber implementation on native windows |
16 | perls. |
204 | perls. |
17 | - use sizeof (void *) as multiplication factor for stack sizes, |
205 | - use sizeof (void *) as multiplication factor for stack sizes, |
… | |
… | |
86 | handle and barfed. now it's just a bit slower on gentoo and similar |
274 | handle and barfed. now it's just a bit slower on gentoo and similar |
87 | systems. |
275 | systems. |
88 | |
276 | |
89 | 6.01 Sun Jul 3 12:31:14 CEST 2011 |
277 | 6.01 Sun Jul 3 12:31:14 CEST 2011 |
90 | - workarounds are good, but the test for whether pthreads are used |
278 | - workarounds are good, but the test for whether pthreads are used |
91 | was not good. thisone should be better. |
279 | was not good. this one should be better. |
92 | - check differently whether gcc generates cfi instructions itself. |
280 | - check differently whether gcc generates cfi instructions itself. |
93 | |
281 | |
94 | 6.0 Wed Jun 29 19:43:35 CEST 2011 |
282 | 6.0 Wed Jun 29 19:43:35 CEST 2011 |
95 | - INCOMPATIBLE CHANGE: unreferenced coro objects will now be |
283 | - INCOMPATIBLE CHANGE: unreferenced coro objects will now be |
96 | destroyed and cleaned up automatically (e.g. async { schedule }). |
284 | destroyed and cleaned up automatically (e.g. async { schedule }). |
97 | - implement a JIT compiler for part of the thread switch code, |
285 | - implement a JIT compiler for part of the thread switch code, |
98 | which gives a 50% speed improvement on threaded perls, and |
286 | which gives a 50% speed improvement on threaded perls, and |
99 | about 4% on non-thraeded perls (so threaded perls now finally |
287 | about 4% on non-threaded perls (so threaded perls now finally |
100 | reach about half the speed of non-threaded perls). |
288 | reach about half the speed of non-threaded perls). |
101 | - slightly modernise Coro::Intro, add section about rouse functions. |
289 | - slightly modernise Coro::Intro, add section about rouse functions. |
102 | - avoid DEFSV and ERRSV, giving another 10% improvement |
290 | - avoid DEFSV and ERRSV, giving another 10% improvement |
103 | in thread switching. |
291 | in thread switching. |
104 | - Coro::State->is_destroyed is now called is_zombie. |
292 | - Coro::State->is_destroyed is now called is_zombie. |
… | |
… | |
458 | - ->throw is now supported on Coro::State objects. |
646 | - ->throw is now supported on Coro::State objects. |
459 | - clean up cctx creation code a bit. |
647 | - clean up cctx creation code a bit. |
460 | - entersub is actually a UNOP, not a LOGOP (not a bugfix). |
648 | - entersub is actually a UNOP, not a LOGOP (not a bugfix). |
461 | |
649 | |
462 | 4.9 Sat Nov 8 17:45:27 CET 2008 |
650 | 4.9 Sat Nov 8 17:45:27 CET 2008 |
463 | - (libcoro) did not preserve rbp with CORO_ASM (we are getting there). |
651 | - (libcoro) did not preserve rbp with CORO_ASM (we are getting there). |
464 | - (libcoro) no longer leak threads in the experimental pthread backend, |
652 | - (libcoro) no longer leak threads in the experimental pthread backend, |
465 | also speed it up considerably. |
653 | also speed it up considerably. |
466 | - (libcoro) do not rely on makecontext passing void *'s unscathed. |
654 | - (libcoro) do not rely on makecontext passing void *'s unscathed. |
467 | - fix compiletime dependencies on libcoro in the Makefile. |
655 | - fix compiletime dependencies on libcoro in the Makefile. |
468 | - cctx_count wasn't always updated properly. |
656 | - cctx_count wasn't always updated properly. |
… | |
… | |
530 | - remove debugging code related to MgPV_nolen_const, also try to |
718 | - remove debugging code related to MgPV_nolen_const, also try to |
531 | make it compile with perl 5.8.6 (yes, apple apparently loves |
719 | make it compile with perl 5.8.6 (yes, apple apparently loves |
532 | outdated software). Reported by John S. |
720 | outdated software). Reported by John S. |
533 | |
721 | |
534 | 4.744 Tue Jul 8 22:06:35 CEST 2008 |
722 | 4.744 Tue Jul 8 22:06:35 CEST 2008 |
535 | - correctly provide default DIE/WARN handlers as documented. |
723 | - correctly provide default DIE/WARN handlers as documented. |
536 | - also overwrite PL_vtbl_sigelem.svt_clear, even though current |
724 | - also overwrite PL_vtbl_sigelem.svt_clear, even though current |
537 | implementations inside perl work fine for us. |
725 | implementations inside perl work fine for us. |
538 | |
726 | |
539 | 4.743 Mon Jun 16 00:21:57 CEST 2008 |
727 | 4.743 Mon Jun 16 00:21:57 CEST 2008 |
540 | - when using Coro::EV without running EV::loop it could |
728 | - when using Coro::EV without running EV::loop it could |
… | |
… | |
562 | - sprinkle "no warnings" freely over everything, also suppress |
750 | - sprinkle "no warnings" freely over everything, also suppress |
563 | warnings for some other modules. |
751 | warnings for some other modules. |
564 | - fix typo in WSAEWOULDBLOCK. |
752 | - fix typo in WSAEWOULDBLOCK. |
565 | |
753 | |
566 | 4.72 Sun May 25 05:14:36 CEST 2008 |
754 | 4.72 Sun May 25 05:14:36 CEST 2008 |
567 | - tweak META.yaml a bit, unfortunately, there is no documented way |
755 | - tweak META.yaml a bit, unfortunately, there is no documented way |
568 | to have optional dependencies with CPAN. doh :( |
756 | to have optional dependencies with CPAN. doh :( |
569 | - avoid running some tests on windows because they would fail due to |
757 | - avoid running some tests on windows because they would fail due to |
570 | perl bug (broken fork, broken pipes...). |
758 | perl bug (broken fork, broken pipes...). |
571 | - work around perl on windows bugs where perl returns undocumented |
759 | - work around perl on windows bugs where perl returns undocumented |
572 | error codes for sysread, syswrite etc. by taking advantage |
760 | error codes for sysread, syswrite etc. by taking advantage |
… | |
… | |
576 | - use unix domain sockets in testsuite to work around |
764 | - use unix domain sockets in testsuite to work around |
577 | common perl implementation bugs on widows (they are emulated by |
765 | common perl implementation bugs on widows (they are emulated by |
578 | tcp sockets on windows. ugh.) |
766 | tcp sockets on windows. ugh.) |
579 | |
767 | |
580 | 4.71 Sat May 24 20:01:27 CEST 2008 |
768 | 4.71 Sat May 24 20:01:27 CEST 2008 |
581 | - fix a bug in Coro::AnyEvent ("Usage: Coro::AnyEvent::_schedule()"). |
769 | - fix a bug in Coro::AnyEvent ("Usage: Coro::AnyEvent::_schedule()"). |
582 | - take advantage of async name resolution of AnyEvent::Util. |
770 | - take advantage of async name resolution of AnyEvent::Util. |
583 | - work around brutal inet_aton override in Coro::LWP. |
771 | - work around brutal inet_aton override in Coro::LWP. |
584 | - take advantage of the readyhook in Coro::EV, for smoother |
772 | - take advantage of the readyhook in Coro::EV, for smoother |
585 | scheduling. |
773 | scheduling. |
586 | |
774 | |
587 | 4.7 Sun May 11 00:32:19 CEST 2008 |
775 | 4.7 Sun May 11 00:32:19 CEST 2008 |
588 | - completely reworked the Coro manpage. |
776 | - completely reworked the Coro manpage. |
589 | - added Coro::AnyEvent, generic event loop integration. |
777 | - added Coro::AnyEvent, generic event loop integration. |
590 | - implement cancel, ready and kill commands in Coro::Debug. |
778 | - implement cancel, ready and kill commands in Coro::Debug. |
591 | - document find_coro in Coro::Debug. |
779 | - document find_coro in Coro::Debug. |
592 | - incompatible change: rename has_stack to has_cctx. |
780 | - incompatible change: rename has_stack to has_cctx. |
593 | - Coro::AIO and Coro::BDB no longer force event model detection, |
781 | - Coro::AIO and Coro::BDB no longer force event model detection, |
594 | use AnyEvent::AIO and AnyEvent::BDB. |
782 | use AnyEvent::AIO and AnyEvent::BDB. |
… | |
… | |
718 | |
906 | |
719 | 4.11 Thu Oct 11 02:40:24 CEST 2007 |
907 | 4.11 Thu Oct 11 02:40:24 CEST 2007 |
720 | - port to threaded perls. |
908 | - port to threaded perls. |
721 | |
909 | |
722 | 4.1 Thu Oct 11 02:38:16 CEST 2007 |
910 | 4.1 Thu Oct 11 02:38:16 CEST 2007 |
723 | - incompatible change: $SIG{__DIE__} and $SIG{__WARN__} will now |
911 | - incompatible change: $SIG{__DIE__} and $SIG{__WARN__} will now |
724 | be local to each coro (see Coro::State). |
912 | be local to each coro (see Coro::State). |
725 | - incompatible change: for very deep reasons, cede and cede_notself |
913 | - incompatible change: for very deep reasons, cede and cede_notself |
726 | cannot return anything, so nothing will be returned. |
914 | cannot return anything, so nothing will be returned. |
727 | - possibly bring back 5.10 compatibility (untested). |
915 | - possibly bring back 5.10 compatibility (untested). |
728 | - work around stupid (and wrong) warning on 5.10 :(. |
916 | - work around stupid (and wrong) warning on 5.10 :(. |
… | |
… | |
800 | but stateful semantics. |
988 | but stateful semantics. |
801 | - fixed a lot of typos in Coro.pm (patch submitted by David |
989 | - fixed a lot of typos in Coro.pm (patch submitted by David |
802 | Steinbrunner, which applied flawlessly). |
990 | Steinbrunner, which applied flawlessly). |
803 | |
991 | |
804 | 3.6 Sat Apr 14 17:13:31 CEST 2007 |
992 | 3.6 Sat Apr 14 17:13:31 CEST 2007 |
805 | - added some bugfixes to get eg/myhttpd working again. |
993 | - added some bugfixes to get eg/myhttpd working again. |
806 | - added Coro::Storable for often-cede'ing freeze/thaw. |
994 | - added Coro::Storable for often-cede'ing freeze/thaw. |
807 | - try to do a clean exit when a coroutine calls exit |
995 | - try to do a clean exit when a coroutine calls exit |
808 | (EXPERIMENTAL). |
996 | (EXPERIMENTAL). |
809 | - got rid of indirect call through _coro_init. |
997 | - got rid of indirect call through _coro_init. |
810 | - updated the partly antique examples in eg/ to |
998 | - updated the partly antique examples in eg/ to |