1 | Revision history for Perl extension Coro. |
1 | Revision history for Perl extension Coro. |
2 | |
2 | |
3 | TODO: check wether stack-sharing is still effective |
3 | TODO: should explore PerlIO::via::CoroCede and PerlIO::via::CoroAIO. |
4 | TODO: more effective stack sharing by having one "default stack" for "simple" coroutines? |
4 | TODO: maybe implement a default message channel, very much like Erlang |
5 | TODO: verify exception frame changes and force stack copies? |
5 | (which is cool in a lot of important aspects (failures!), |
|
|
6 | but very lacking in others (higher level ipc)). |
6 | |
7 | |
7 | - minor documentation cleanup. |
8 | - enable/disable tracing from a new coroutine, not a pooled one. |
|
|
9 | - fix a memleak in Coro::Event. |
|
|
10 | - removed killall call from fork_eval. |
|
|
11 | - made sure store_fd is already loaded so that fork_eval |
|
|
12 | does not have to parse autoload in each subprocess. |
|
|
13 | |
|
|
14 | 4.13 Wed Oct 24 07:26:45 CEST 2007 |
|
|
15 | - add Coro::Storable::blocking_thaw. |
|
|
16 | - use a vastly more complicated technique to localise |
|
|
17 | $SIG{__WARN/DIE__} that also works on perls <= 5.8.8. |
|
|
18 | - use a coroutine for the idle callback Coro::Event, |
|
|
19 | instead of running Event in the current coroutine context. |
|
|
20 | This also catches recursive invocations. |
|
|
21 | - actually report fork errors in gethostbyname and inet_aton. |
|
|
22 | |
|
|
23 | 4.11 Thu Oct 11 02:40:24 CEST 2007 |
|
|
24 | - port to threaded perls. |
|
|
25 | |
|
|
26 | 4.1 Thu Oct 11 02:38:16 CEST 2007 |
|
|
27 | - incompatible change: $SIG{__DIE__} and $SIG{__WARN__} will now |
|
|
28 | be local to each coro (see Coro::State). |
|
|
29 | - incompatible change: for very deep reasons, cede and cede_notself |
|
|
30 | cannot return anything, so nothing will be returned. |
|
|
31 | - possibly bring back 5.10 compatibility (untested). |
|
|
32 | - work around stupid (and wrong) warning on 5.10 :(. |
|
|
33 | - overlay the saved state over the context stack. This saves |
|
|
34 | a few hundred bytes per coroutine on average and also |
|
|
35 | speeds up context switching a bit. |
|
|
36 | - further tune default stack sizes. |
|
|
37 | - (more) correctly calculate stack usage in coro_rss. |
|
|
38 | - Coro::Storable::blocking_* did not properly lock |
|
|
39 | resulting in races between coroutines. |
|
|
40 | - added Coro::Storable::guard. |
|
|
41 | - stopping to trace a coroutine could destroy the cctx of |
|
|
42 | an unrelated coroutine. |
|
|
43 | - explain the relationship between Perl and C coroutines in |
|
|
44 | more detail in Coro::State. |
|
|
45 | - Coro::Util::inet_aton did not short-circuit dotted quad forms, |
|
|
46 | causing a fork per resolve. This also affected Coro::Socket. |
|
|
47 | - switch to a separate stack in $coro->call/eval to avoid |
|
|
48 | invalidating pointers. |
|
|
49 | |
|
|
50 | 4.03 Sat Oct 6 21:24:00 CEST 2007 |
|
|
51 | - added Coro::throw method. |
|
|
52 | - minor code cleanups. |
|
|
53 | |
|
|
54 | 4.02 Sat Oct 6 02:36:47 CEST 2007 |
|
|
55 | - fix a very minor per-coroutine memleak (a single codereference). |
|
|
56 | - fixed a bug where the currently in-use c context would be freed |
|
|
57 | prematurely (can happen only when programs change the stacksize |
|
|
58 | or use tracing). |
|
|
59 | - tracing can no longer keep a coro alive after it terminated. |
|
|
60 | - do static branch prediction in the common path for gcc. gives |
|
|
61 | about 2-5% speed improvement here. |
|
|
62 | |
|
|
63 | 4.01 Fri Oct 5 22:10:49 CEST 2007 |
|
|
64 | - instead of recreating *a* standard output handle we simply |
|
|
65 | use STDOUT, which is faster and hopefully more robust. |
|
|
66 | |
|
|
67 | 4.0 Fri Oct 5 12:56:00 CEST 2007 |
|
|
68 | - incompatibly changed Coro::Storable::freeze. |
|
|
69 | - major new feature: added Coro::Debug, for interactive coroutine |
|
|
70 | debugging, tracing and much more. |
|
|
71 | - major bug fix: unbelievable, but true: $_, $/ and many other |
|
|
72 | "saved" variables actually weren't being saved. This has been fixed, |
|
|
73 | of course, while increasing performance while losing all the save |
|
|
74 | flags. |
|
|
75 | - save flags are gone, and all the api functions dealing with them. |
|
|
76 | - added Coro::Semaphore::adjust. |
|
|
77 | - added Coro::Util::fork_eval. |
|
|
78 | - added Coro::Storable::{nfreeze,blocking_{freeze,nfreeze}}. |
|
|
79 | - added Coro::killall. |
|
|
80 | - reduce initial stack sizes to allow for "micro-coroutines". |
|
|
81 | - better async_pool resource management, moved parts of async_pool |
|
|
82 | handling to XS (major speed improvement). |
|
|
83 | - actually croak before modifying important data structures. |
|
|
84 | - refuse to transfer while compiling. |
|
|
85 | - possibly support eval EXPR better now. |
|
|
86 | - enable assembly per default on linux+bsd x86+amd64. |
|
|
87 | - all internal members were renamed _something for easier subclassing. |
|
|
88 | - many minor tweaks. |
|
|
89 | |
|
|
90 | 3.63 Wed May 16 14:10:06 CEST 2007 |
|
|
91 | - implement handcoded assembly for x86/amd64 SVR ABI. |
|
|
92 | |
|
|
93 | 3.62 Fri Apr 27 21:36:06 CEST 2007 |
|
|
94 | - upgrade libcoro (which might set unwind info correctly). |
|
|
95 | - change default on linux to setjmp/longjmp. |
|
|
96 | |
|
|
97 | 3.61 Thu Apr 19 12:36:18 CEST 2007 |
|
|
98 | - Coro::Storable caused an endless loop when thawing invalid |
|
|
99 | pst's sometimes. |
|
|
100 | - use a Semaphore in Coro::Storable, as Storable doesn't |
|
|
101 | seem to be reentrant (although it is documented to |
|
|
102 | be threadsafe...). |
|
|
103 | - fix Coro::Signal to bring back the original unreliable |
|
|
104 | but stateful semantics. |
|
|
105 | - fixed a lot of typos in Coro.pm (patch submitted by David |
|
|
106 | Steinbrunner, which applied flawlessly). |
|
|
107 | |
|
|
108 | 3.6 Sat Apr 14 17:13:31 CEST 2007 |
|
|
109 | - added some bugfixes to get eg/myhttpd working again. |
|
|
110 | - added Coro::Storable for often-cede'ing freeze/thaw. |
|
|
111 | - try to do a clean exit when a coroutine calls exit |
|
|
112 | (EXPERIMENTAL). |
|
|
113 | - got rid of indirect call through _coro_init. |
|
|
114 | - updated the partly antique examples in eg/ to |
|
|
115 | work again and be a bit less magic, too. |
|
|
116 | - fixed Coro::Signal semantics to work as documented again. |
|
|
117 | |
|
|
118 | 3.55 Sun Mar 25 01:20:47 CET 2007 |
|
|
119 | - add SAVE_DEFFH to save the default filehandle and enable |
|
|
120 | it by default. |
|
|
121 | - finally move socket-operations from Coro::Socket to Coro::Handle |
|
|
122 | to be able to unblock foreign sockets. |
|
|
123 | - add Coro::State::save_also and guarded_save. |
|
|
124 | - add count accessor to Coro::Semaphore. |
|
|
125 | - add Coro::State::cctx_stacksize. |
|
|
126 | - just for the fun of it, do not rely on implicit context, |
|
|
127 | which can dramatically improve performance, but people |
|
|
128 | using windows-process-emulation perls do not care much about |
|
|
129 | performance. |
|
|
130 | |
|
|
131 | 3.51 Sun Mar 4 14:18:04 CET 2007 |
|
|
132 | - fixed a problem when you weakened references to Coro::State's |
|
|
133 | (patch by Yuval Kogman). |
|
|
134 | |
|
|
135 | 3.501 Wed Feb 28 12:44:07 CET 2007 |
|
|
136 | - rename some global symbols as macosx from hell redefines |
|
|
137 | them without asking. |
|
|
138 | |
|
|
139 | 3.5 Tue Feb 13 20:22:53 CET 2007 |
|
|
140 | - do AnyEvent model detection earlier, avoiding problems |
|
|
141 | caused by first using AnyEvent and later Coro::Event. |
|
|
142 | - implement and document Coro::Event event objects. |
|
|
143 | - fix a potential problem in Coro::Event causing crashes. |
|
|
144 | - initialise PL_comppad when creating a new coroutine, |
|
|
145 | avoids crashes on early coro destruction. |
|
|
146 | |
|
|
147 | 3.41 Mon Jan 22 19:19:49 CET 2007 |
|
|
148 | - readline on Coro::Handle did not support undefined $/, |
|
|
149 | nor did it deliver partial lines on EOF or error. |
|
|
150 | - implement malloc fallback for stack allocation because |
|
|
151 | stupid broken idiotic OSX has a stupid broken |
|
|
152 | idiotic fits-the-whole-os mmap "implementation" and |
|
|
153 | my dick feels longer if Coro is portable even to |
|
|
154 | obsolete platforms. |
|
|
155 | |
|
|
156 | 3.4 Fri Jan 19 21:52:54 CET 2007 |
|
|
157 | - remove t/09_timer.t, as it isn't really testing much |
|
|
158 | but was rather flaky in practise. |
|
|
159 | - async_pool coro would keep arguments and callback alive until |
|
|
160 | it was reused. |
|
|
161 | - cancellation of a coroutine could cause spurious idle calls |
|
|
162 | in cede_notself. |
|
|
163 | |
|
|
164 | 3.3 Sat Jan 6 03:45:00 CET 2007 |
|
|
165 | - implement $coro->on_destroy. |
|
|
166 | - Coro::Event blocking semantics have been changed, |
|
|
167 | documented and - hopefully - improved. |
|
|
168 | - fix nice adding, not subtracting, from priority. |
|
|
169 | - fix ->prio and api_is_ready (patch by Mark Hinds). |
|
|
170 | - fixed an assert ("... == prev__cctx->idle_te") |
|
|
171 | that could errronously trigger. |
|
|
172 | - fix various large and small memleaks. |
|
|
173 | - use a (hopefully) more stable cancel implementation |
|
|
174 | that immediately frees the coroutine data. |
|
|
175 | - cede/cede_notself return a status now. |
|
|
176 | - added Coro::guard function. |
|
|
177 | - added a global coroutine pool for jobs (on my machine, |
|
|
178 | I can create and execute 48k simple coros/s with async, |
|
|
179 | and 128k coros with async_pool). |
|
|
180 | - Coro::AIO now uses the coroutine priority as io priority. |
|
|
181 | |
|
|
182 | 3.2 Fri Dec 22 05:07:09 CET 2006 |
|
|
183 | - improve portability to slightly older perls. |
|
|
184 | - use cleaner coroutine destruction. |
|
|
185 | - simplify configuration for users. |
|
|
186 | - optionally (unrecommended) prefer perl functions over |
|
|
187 | their coro replacements. |
|
|
188 | |
|
|
189 | 3.11 Tue Dec 5 13:11:24 CET 2006 |
|
|
190 | - fixed some bogus assert's, but as perl.h disables assert even |
|
|
191 | without NDEBUG (thank you very much), not too many people should |
|
|
192 | notice (that did include myself). Andreas König noticed, though :) |
|
|
193 | - do not save/restore PL_sortcxix on >= 5.9.x, it doesn't seem to have |
|
|
194 | it. Also noticed by Andreas König :) |
|
|
195 | - save/restore tainted status. |
|
|
196 | - verified to pass the testsuite on my 5.9.5. |
|
|
197 | |
|
|
198 | 3.1 Mon Dec 4 23:03:40 CET 2006 |
|
|
199 | - INCOMPATIBLE CHANGE: $/ is now per-coroutine (but slow). |
|
|
200 | - incompatible change: transfer flags are now per-state. |
|
|
201 | - give a better error message on deadlock. |
|
|
202 | - document Coro::nready. |
|
|
203 | - enhanced testsuite. |
|
|
204 | |
|
|
205 | 3.01 Sun Dec 3 23:47:42 CET 2006 |
|
|
206 | - forgot to include Coro::Timer. |
|
|
207 | |
|
|
208 | 3.0 Sun Dec 3 22:57:25 CET 2006 |
|
|
209 | - the "FINALLY COMPLETELY STABLE" release (coming soon: |
|
|
210 | the "FAMOUS LAST WORDS" release). |
|
|
211 | - implement a new stack sharing algorithm, which uses a stack |
|
|
212 | pool (size currently hardcoded). |
|
|
213 | - make stack sharing mandatory (it no longer uses a heuristic). |
|
|
214 | - eval/die no longer cause weird problems under heavy use. |
|
|
215 | - Coro::Event could cause livelocks if it was used but |
|
|
216 | no Coro::Event watchers were used. |
|
|
217 | - Coro::Event now uses asynccheck as prepare does not |
|
|
218 | check for changed watchers. |
|
|
219 | - Coro::Event allows multiple waiting coros and will wake up one |
|
|
220 | per event. |
|
|
221 | - Coro::Event should be cleaner and more efficient now. |
|
|
222 | - new utility function Coro::unblock_sub. |
|
|
223 | - document the sad fact that Event is no longer reentrant. |
|
|
224 | - putting a coroutine into the ready queue twice could under |
|
|
225 | some circumstances lead to stack corruption. |
|
|
226 | - minor incompatibility: subclassing Coro::State is supported |
|
|
227 | directly now without going through a _coro_state member. |
|
|
228 | - state/coro switching is much faster now. |
|
|
229 | - very minor optimisations and code/documentation cleanup. |
|
|
230 | - avoid problems due to compiler inlining. |
|
|
231 | - removed timers from Coro::Timer -> use AnyEvent instead. |
|
|
232 | - replaced Coro::idle coroutine by (cleaner) idle handler. |
|
|
233 | - updated to newest libcoro. |
|
|
234 | - implement enhanced support for valgrind. |
|
|
235 | - implement is_ready and return value for ready. |
|
|
236 | - removed Coro::Cont, it was a misnomer (it's generators), |
|
|
237 | and it was somewhat annoying to get it right. Will come back |
|
|
238 | if somebody asks for it :) |
|
|
239 | - many ->wait methods and Coro::Event could return |
|
|
240 | spuriously without the event having happened. |
8 | |
241 | |
9 | 2.5 Tue Nov 7 12:22:33 CET 2006 |
242 | 2.5 Tue Nov 7 12:22:33 CET 2006 |
10 | - made Coro::Util, Coro::Select, Coro::Handle and Coro::Socket |
243 | - made Coro::Util, Coro::Select, Coro::Handle and Coro::Socket |
11 | use AnyEvent, moved them to Coro/. |
244 | use AnyEvent, moved them to Coro/. |
12 | - added Coro::LWP which contains all the uglyness required to |
245 | - added Coro::LWP which contains all the uglyness required to |